From 0a009302eed4f3dd2534578848b5a4f60b0440f3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=82=93=E6=B4=81?= <209192278@qq.com> Date: Tue, 23 May 2023 01:20:27 +0800 Subject: [PATCH] =?UTF-8?q?=E9=82=93=E6=B4=81=20:=20=E4=BF=AE=E6=94=B9?= =?UTF-8?q?=E4=BA=A7=E5=93=81=E4=B8=AD=E5=BF=83bug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/router/index.js | 6 + src/views/productsCenter/index.vue | 187 ++++++++++++++++++++++++----- 2 files changed, 166 insertions(+), 27 deletions(-) diff --git a/src/router/index.js b/src/router/index.js index 7707cd5..17b9bc7 100644 --- a/src/router/index.js +++ b/src/router/index.js @@ -47,6 +47,12 @@ const routes = [ name: 'products_center', component: () => import('../views/productsCenter/index') }, + { + path: '/products_center/:menu/:menuTitle', + name: 'products_center', + props:true, + component: () => import('../views/productsCenter/index') + }, { path: '/products_detail', name: 'products_detail', diff --git a/src/views/productsCenter/index.vue b/src/views/productsCenter/index.vue index fc06188..6d233cc 100644 --- a/src/views/productsCenter/index.vue +++ b/src/views/productsCenter/index.vue @@ -38,7 +38,7 @@ -
+
暂时没有数据!
@@ -69,7 +69,7 @@ export default { }, watch: { $route(to) { - if (to.query.menu) { + if (to.query.menu!==undefined&&to.query.classify===undefined&&to.query.style===undefined&&to.query.space===undefined) { for (let i = 0; i < this.productTabs.length; i++) { if (this.productTabs[i].id == to.query.menu) { this.$refs.ProductsTabsItem.activeName = i + ""; @@ -88,6 +88,12 @@ export default { this.imgList = res.data.list; }); } + + if(to.query.classify!==0&&to.query.classify!==undefined){ + this.getGoodsList(to.query.classify, 1, this.pageSize, to.query.style, to.query.space); + } else if (to.query.classify == 0) { + this.getGoodsList(to.query.menu, 1, this.pageSize, to.query.style, to.query.space); + } } }, beforeUpdate() { @@ -98,34 +104,59 @@ export default { } } } - if (this.$route.query.menuTitle) { + if (this.$route.query.classify) { for (let i = 0; i < this.classifyList.length; i++) { const red = document.getElementById("classify_" + i); - if (this.classifyList[i].name == this.$route.query.menuTitle) { + if (this.classifyList[i].id == this.$route.query.classify) { red.style = "color: #f00!important;text-decoration: underline!important;"; } else { red.style = "color: #000!important;"; } } + }else { + for (let i = 0; i < this.classifyList.length; i++) { + const red = document.getElementById("classify_" + i); + red.style = "color: #000!important;"; + } + } + if (this.$route.query.space) { for (let i = 0; i < this.spaceList.length; i++) { const red = document.getElementById("space_" + i); - if (this.spaceList[i].title == this.$route.query.menuTitle) { + if (this.spaceList[i].title == this.$route.query.space) { red.style = "color: #f00!important;text-decoration: underline!important;"; } else { red.style = "color: #000!important;"; } } + }else { + for (let i = 0; i < this.spaceList.length; i++) { + const red = document.getElementById("space_" + i); + red.style = "color: #000!important;"; + } + } + if (this.$route.query.style) { for (let i = 0; i < this.styleList.length; i++) { const red = document.getElementById("style_" + i); - if (this.styleList[i].title == this.$route.query.menuTitle) { + if (this.styleList[i].title == this.$route.query.style) { red.style = "color: #f00!important;text-decoration: underline!important;"; } else { red.style = "color: #000!important;"; } } + }else { + for (let i = 0; i < this.styleList.length; i++) { + const red = document.getElementById("style_" + i); + red.style = "color: #000!important;"; + } } }, mounted() { + if(this.$route.query.menu&&this.$route.query.space){ + getGoodsCategory(this.$route.query.menu).then(res => { + this.classifyList = res.data.categorylist; + }); + this.getGoodsList(this.classIndex, 1, this.pageSize, "", this.$route.query.space); + } getPublicData().then(res => { this.productTabs = res.data.goodscategory_list; }); @@ -134,18 +165,18 @@ export default { this.spaceList = res.data.space_list; this.styleList = res.data.style_list; }); - if (this.$route.query.menu) { + if (this.$route.query.menu&&this.$route.query.space==undefined) { //进入页面时, 获取第一个列表的类别 getGoodsCategory(this.$route.query.menu).then(res => { this.classifyList = res.data.categorylist; }); this.getGoodsList(this.$route.query.menu, 1, this.pageSize); - } else { + }else if (this.$route.query.menu==undefined&&this.$route.query.space==undefined){ //进入页面时, 获取第一个列表的类别 getGoodsCategory(1).then(res => { this.classifyList = res.data.categorylist; }); - this.getGoodsList(0, 1, this.pageSize); + this.getGoodsList(1, 1, this.pageSize); } }, methods: { @@ -160,9 +191,12 @@ export default { }).then(res => { this.total = res.data.count; this.imgList = res.data.list; - if (res.data.list.length === 0) { + if (res.data.list.length == 0) { this.showNull = true; this.showPagination = false; + }else { + this.showNull = false; + this.showPagination = true; } }); }, @@ -170,6 +204,12 @@ export default { handleClick(tab) { let index = parseInt(tab.index) + 1; this.classIndex = index; + this.$router.push({ + path: "/products_center", + query: { + menu: index + } + }); getGoodsCategory(index).then(res => { this.classifyList = res.data.categorylist; }); @@ -181,33 +221,126 @@ export default { }, //点击二级分类,筛选产品数据 changeClassify(item) { - this.$router.push({ - path: "/products_center", - query: { - menuTitle: item.name - } - }); - this.getGoodsList(item.id, 1, this.pageSize); + let menu=this.$route.query.menu + let space=this.$route.query.space + let style=this.$route.query.style + if(menu===undefined){ + const menuOne=1 + menu=menuOne + }if(space===undefined){ + const menuOne=0 + space=menuOne + }if(style===undefined){ + const menuOne=0 + style=menuOne + } + // if(space==undefined&&style==undefined){ + // this.$router.push({ + // path: '/products_center', + // query: { + // classify: item.name + // } + // }); + // }else if(style==undefined){ + // this.$router.push({ + // path: `/products_center?menu=${menu}&space=${space}`, + // query: { + // classify: item.name + // } + // }); + // }else if(space==undefined){ + // this.$router.push({ + // path: `/products_center?menu=${menu}&style=${style}`, + // query: { + // classify: item.name + // } + // }); + // }else { + this.$router.push({ + path: `/products_center?menu=${menu}&space=${space}&style=${style}`, + query: { + classify: item.id + } + }); + // } + // this.getGoodsList(item.id, 1, this.pageSize); }, //点击空间分类,筛选产品数据 changeSpace(item) { - this.$router.push({ - path: "/products_center", - query: { - menuTitle: item.title - } - }); - this.getGoodsList(this.classIndex, 1, this.pageSize, "", item.title); + let menu=this.$route.query.menu + let style=this.$route.query.style + let classify=this.$route.query.classify + if(menu===undefined){ + const menuOne=1 + menu=menuOne + }if(style===undefined){ + const menuOne=0 + style=menuOne + }if(classify===undefined){ + const menuOne=0 + classify=menuOne + } + // if(style!==undefined){ + // this.$router.push({ + // path: `/products_center?menu=${menu}&style=${style}`, + // query: { + // space: item.title + // } + // }); + // }else if(style==undefined&&classify==undefined){ + // this.$router.push({ + // path: `/products_center?menu=${menu}`, + // query: { + // space: item.title + // } + // }); + // }else if(style!==undefined&&space!==undefined){ + this.$router.push({ + path: `/products_center?menu=${menu}&classify=${classify}&style=${style}`, + query: { + space: item.title + } + }); + // } + // this.getGoodsList(this.classIndex, 1, this.pageSize, "", item.title); }, //点击风格分类,筛选产品数据 changeStyle(item) { + let menu=this.$route.query.menu + let space=this.$route.query.space + let classify=this.$route.query.classify + if(menu===undefined){ + const menuOne=1 + menu=menuOne + } if(space===undefined){ + const menuOne=0 + space=menuOne + } if(classify===undefined){ + const menuOne=0 + classify=menuOne + } this.$router.push({ - path: "/products_center", + path: `/products_center?menu=${menu}&classify=${classify}&space=${space}`, query: { - menuTitle: item.title + style: item.title } }); - this.getGoodsList(this.classIndex, 1, this.pageSize, item.title, ""); + // if(space!==undefined){ + // this.$router.push({ + // path: `/products_center?menu=${menu}&space=${space}`, + // query: { + // style: item.title + // } + // }); + // }else { + // this.$router.push({ + // path: `/products_center?menu=${menu}`, + // query: { + // style: item.title + // } + // }); + // } + // this.getGoodsList(this.classIndex, 1, this.pageSize, item.title, ""); } } };