二级分类
整体认识和页面渲染
1. 准备组件模版
vue
<script setup></script>
<template>
<div class="container ">
<!-- 面包屑 -->
<div class="bread-container">
<el-breadcrumb separator=">">
<el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item>
<el-breadcrumb-item :to="{ path: '/' }">居家 </el-breadcrumb-item>
<el-breadcrumb-item>居家生活用品</el-breadcrumb-item>
</el-breadcrumb>
</div>
<div class="sub-container">
<el-tabs>
<el-tab-pane label="最新商品" name="publishTime"></el-tab-pane>
<el-tab-pane label="最高人气" name="orderNum"></el-tab-pane>
<el-tab-pane label="评论最多" name="evaluateNum"></el-tab-pane>
</el-tabs>
<div class="body">
<!-- 商品列表-->
</div>
</div>
</div>
</template>
<style lang="scss" scoped>
...
</style>
2. 配置路由
javascript
import { createRouter, createWebHashHistory } from "vue-router";
import Layout from "@/views/Layout/index.vue";
import SubCategory from "@/views/SubCategory/index.vue";
const router = createRouter({
history: createWebHashHistory(import.meta.env.BASE_URL),
routes: [
{
path: "/",
name: "layout",
component: Layout,
children: [
{
path: "category/sub/:id",
name: "subCategory",
component: SubCategory,
},
],
},
],
});
export default router;
3. 跳转配置
html
<div class="sub-list">
<h3>全部分类</h3>
<ul>
<li v-for="i in categoryData.children" :key="i.id">
<RouterLink :to="`/category/sub/${i.id}`">
<img :src="i.picture" />
<p>{{ i.name }}</p>
</RouterLink>
</li>
</ul>
</div>
面包屑导航实现
1. 准备接口
javascript
/**
* @description: 获取二级分类列表数据
* @param {*} id 分类id
* @return {*}
*/
export const getCategoryFilterAPI = (id) => {
return request({
url: "/category/sub/filter",
params: {
id,
},
});
};
2. 获取数据渲染模版
vue
<script setup>
import { getCategoryFilterAPI } from "@/apis/category";
// 获取面包屑导航数据
const filterData = ref({});
const getFilterData = async () => {
const res = await getCategoryFilterAPI(route.params.id);
filterData.value = res.result;
};
getFilterData();
</script>
<template>
<div class="bread-container">
<el-breadcrumb separator=">">
<el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item>
<el-breadcrumb-item :to="{ path: `/category/${filterData.parentId}` }">
{{ filterData.parentName }}
</el-breadcrumb-item>
<el-breadcrumb-item>{{ filterData.name }}</el-breadcrumb-item>
</el-breadcrumb>
</div>
</template>
分类基础列表实现
1. 准备接口
javascript
/**
* @description: 获取分类导航数据
* @data {
categoryId: 1005000 ,
page: 1,
pageSize: 20,
sortField: 'publishTime' | 'orderNum' | 'evaluateNum'
}
* @return {*}
*/
export const getSubCategoryAPI = (data) => {
return request({
url: "/category/goods/temporary",
method: "POST",
data,
});
};
2. 获取数据列表
vue
<script setup>
// 获取基础列表数据渲染
const goodList = ref([]);
const reqData = ref({
categoryId: route.params.id,
page: 1,
pageSize: 20,
sortField: "publishTime",
});
const getGoodList = async () => {
const res = await getSubCategoryAPI(reqData.value);
console.log(res);
goodList.value = res.result.items;
};
onMounted(() => getGoodList());
</script>
列表筛选实现
思路:tab 组件切换时修改 reqData 中的 sortField 字段,重新拉取接口列表
vue
<script setup>
// tab切换回调
const tabChange = (val) => {
reqData.value.sortField = val; // 筛选条件
reqData.value.page = 1;
getGoodList();
};
</script>
<template>
<el-tabs v-model="reqData.sortField" @tab-change="tabChange">
<el-tab-pane label="最新商品" name="publishTime"></el-tab-pane>
<el-tab-pane label="最高人气" name="orderNum"></el-tab-pane>
<el-tab-pane label="评论最多" name="evaluateNum"></el-tab-pane>
</el-tabs>
</template>
无限加载实现
基础思路
- v-infinite-scroll 监听滚动事件,判断是否触底
- 触底条件满足之后 page++,拉取下一页数据
- 新老数据做数组拼接
- 判断是否已经全部加载完毕,停止监听
vue
<template>
<!-- 监听滚动 -->
<div
class="body"
v-infinite-scroll="load"
:infinite-scroll-disabled="disabled"
>
<!-- 商品列表-->
<GoodsItem v-for="item in goodList" :good="item" />
</div>
</template>
<script>
// 加载更多
const disabled = ref(false);
const load = async () => {
// 获取下一页的数据
reqData.value.page++;
const res = await getSubCategoryAPI(reqData.value);
goodList.value = [...goodList.value, ...res.result.items];
// 加载完毕 停止监听
if (res.result.items.length === 0) {
disabled.value = true;
}
};
</script>
路由滚动优化
js
const router = createRouter({
// 更新路由自动滚动到顶部
scrollBehavior() {
return {
top: 0,
};
},
});