邓洁 : 接口对接完成,菜单切换等编写完成 #18

Merged
odjbin merged 1 commits from dj into master 2023-05-21 17:31:27 +00:00
16 changed files with 720 additions and 277 deletions

BIN
src/assets/index/cbg0.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 196 KiB

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="aboutUs"> <div class="aboutUs">
<el-row style=""> <el-row>
<el-row> <el-row>
<div class="about_title"> <div class="about_title">
<h2>关于我们</h2> <h2>关于我们</h2>
@ -21,8 +21,8 @@
</el-row> </el-row>
<el-row :gutter="10" style="padding: 0 5% "> <el-row :gutter="10" style="padding: 0 5% ">
<el-col :span="8" v-for="(imgTextItem,imgTextIndex) in imgTextList" :key="imgTextIndex" <el-col :span="8" v-for="(imgTextItem,imgTextIndex) in imgTextList" :key="imgTextIndex"
:class="'culture_'+imgTextIndex"> :class="'culture_'+imgTextIndex" >
<div class="imgAndText"> <div class="imgAndText" @click="handleChangeMenu(imgTextItem)">
<a :href="imgTextItem.href"> <a :href="imgTextItem.href">
<span class="pic"> <span class="pic">
<img :src="imgTextItem.src" alt=""/> <img :src="imgTextItem.src" alt=""/>
@ -48,6 +48,8 @@
</template> </template>
<script> <script>
import {getArticleInfo} from "@/api";
export default { export default {
name: "AboutUs", name: "AboutUs",
data() { data() {
@ -77,26 +79,46 @@ export default {
], ],
imgTextList: [ imgTextList: [
{ {
href: '', id: '',
src: require('../assets/index/a1.jpg'), src: require('../assets/index/a1.jpg'),
boldText: 'Brand', boldText: 'Brand',
enText: 'culture', enText: 'culture',
cnTitle: '品牌文化' cnTitle: ''
}, { }, {
href: '', id: '',
src: require('../assets/index/a2.jpg'), src: require('../assets/index/a2.jpg'),
boldText: 'Enterprise', boldText: 'Enterprise',
enText: 'viewpoint', enText: 'viewpoint',
cnTitle: '企业观点' cnTitle: ''
}, { }, {
href: '', id: '',
src: require('../assets/index/a3.jpg'), src: require('../assets/index/a3.jpg'),
boldText: 'corporate', boldText: 'corporate',
enText: 'culture', enText: 'culture',
cnTitle: '企业文化' cnTitle: ''
} }
] ]
} }
},
created() {
getArticleInfo(1).then(res => {
this.imgTextList[0].id = res.data.articlelist[1].id;
this.imgTextList[1].id = res.data.articlelist[2].id;
this.imgTextList[2].id = res.data.articlelist[3].id;
this.imgTextList[0].cnTitle = res.data.articlelist[1].title;
this.imgTextList[1].cnTitle = res.data.articlelist[2].title;
this.imgTextList[2].cnTitle = res.data.articlelist[3].title;
});
},
methods: {
handleChangeMenu(imgTextItem) {
this.$router.push({
path: "/about_us", //
query: { //
menu: imgTextItem.id,
}
});
}
} }
} }
</script> </script>
@ -117,7 +139,7 @@ export default {
.aboutUs { .aboutUs {
min-width: 1300px; min-width: 1300px;
width: 1360px; width: 1360px;
margin: 0 auto 50px auto; margin: 60px auto 50px auto;
.about_title { .about_title {
display: inline; display: inline;

View File

@ -14,7 +14,7 @@
<ul> <ul>
<li v-for="(moduleItem,moduleIndex) in moduleList" :key="moduleIndex" :id="'find_'+moduleIndex" <li v-for="(moduleItem,moduleIndex) in moduleList" :key="moduleIndex" :id="'find_'+moduleIndex"
@mouseenter="changeFinds(moduleIndex)"> @mouseenter="changeFinds(moduleIndex)">
<a :href="moduleItem.href"> <a :href="moduleItem.href" >
<span> <span>
<img :src="moduleItem.src" alt=""/> <img :src="moduleItem.src" alt=""/>
</span> </span>
@ -27,12 +27,12 @@
</div> </div>
<div style="border-bottom: 1px solid #e9e9e9;"> <div style="border-bottom: 1px solid #e9e9e9;">
<div class="classify" v-if="findIndex===0"> <div class="classify" v-if="findIndex===0">
<a v-for="(childrenItem,childrenIndex) in findList" :key="childrenIndex"> <a v-for="(childrenItem,childrenIndex) in findList" :key="childrenIndex" @click.stop="handleChangeMenu(childrenItem)">
{{ childrenItem.name }} {{ childrenItem.name }}
</a> </a>
</div> </div>
<div class="classify" v-else> <div class="classify" v-else>
<a v-for="(childrenItem,childrenIndex) in findList" :key="childrenIndex"> <a v-for="(childrenItem,childrenIndex) in findList" :key="childrenIndex" @click.stop="handleChangeMenu(childrenItem)">
{{ childrenItem.title }} {{ childrenItem.title }}
</a> </a>
</div> </div>
@ -95,6 +95,15 @@ export default {
this.findList = res.data.style_list; this.findList = res.data.style_list;
}); });
} }
},
handleChangeMenu(childrenItem) {
this.$router.push({
path: "/products_center", //
query: { //
menu: childrenItem.id,
menuTitle:childrenItem.title//type
}
});
} }
} }
}; };

View File

@ -21,7 +21,7 @@
<div class="news_right"> <div class="news_right">
<div class="classify"> <div class="classify">
<ul> <ul>
<li v-for="(item,index) in classifyList" :key="index"> <li v-for="(item,index) in classifyList" :key="index" @click="handleChangeMenu(item)">
<a :href="item.href">{{ item.title }}</a> <a :href="item.href">{{ item.title }}</a>
</li> </li>
</ul> </ul>
@ -31,13 +31,13 @@
<ul> <ul>
<li v-for="(item,index) in itemList" :key="index"> <li v-for="(item,index) in itemList" :key="index">
<div class="pics"> <div class="pics">
<a :href="item.href"> <a :href="item.href" @click="handleToDetail(item)">
<img :src="item.image" alt=""/> <img :src="item.image" alt=""/>
</a> </a>
</div> </div>
<div class="info"> <div class="info">
<div class="title"> <div class="title">
<a :href="item.href">{{ item.title }}</a> <a :href="item.href" @click="handleToDetail(item)">{{ item.title }}</a>
</div> </div>
<div class="smy">{{ item.synopsis }}</div> <div class="smy">{{ item.synopsis }}</div>
<div class="dates">发布时间{{ item.create_time }}</div> <div class="dates">发布时间{{ item.create_time }}</div>
@ -61,14 +61,13 @@ export default {
news_summary: "坚持以科技创新推进产品革新,“以质量为生命”保障产品品质。秉承工匠精神,每一片瓷砖都经过从原料到产品进库数百道工序的精心打造,数十项物理性能检测和表面效果把关,为全球消费者及采购商提供高品质的产品。", news_summary: "坚持以科技创新推进产品革新,“以质量为生命”保障产品品质。秉承工匠精神,每一片瓷砖都经过从原料到产品进库数百道工序的精心打造,数十项物理性能检测和表面效果把关,为全球消费者及采购商提供高品质的产品。",
classifyList: [ classifyList: [
{ {
href: "/news", id: 5,
title: "公司新闻" title: "公司新闻"
}, }, {
{ id: 6,
href: "",
title: "行业动态" title: "行业动态"
}, { }, {
href: "", id: 7,
title: "瓷砖百科" title: "瓷砖百科"
} }
], ],
@ -83,6 +82,24 @@ export default {
}).then(res => { }).then(res => {
this.itemList = res.data.list; this.itemList = res.data.list;
}); });
},
methods:{
handleChangeMenu(item){
this.$router.push({
path: "/news", //
query: { //
menu: item.id,
}
});
},
handleToDetail(item){
this.$router.push({
path: "/news", //
query: { //
menuDetail: item.id,
}
});
}
} }
}; };
</script> </script>

View File

@ -23,7 +23,7 @@
<span class="info">{{ item.create_time }}</span> <span class="info">{{ item.create_time }}</span>
</div> </div>
<!--形象展示放大 --> <!--形象展示放大 -->
<div v-if="type===22"> <div v-if="type===22" style="display: inline-block">
<div class="bigImg"> <div class="bigImg">
<el-image <el-image
:src="item.image"> :src="item.image">
@ -36,6 +36,19 @@
</ul> </ul>
</el-col> </el-col>
</el-row> </el-row>
<div v-show="showMask">
<div class="mask">
</div>
<div class="mask_pic">
<div class="pic_bgc">
<div>
<i class="el-icon-close close" @click="closeMask"></i>
<img :src="mask_pic" alt=""/>
</div>
<span class="mask_info">{{ mask_title }}</span>
</div>
</div>
</div>
</div> </div>
</template> </template>
@ -53,7 +66,11 @@ export default {
newsItem: String newsItem: String
}, },
data() { data() {
return {}; return {
showMask: false,
mask_pic: "",
mask_title: ""
};
}, },
methods: { methods: {
/** /**
@ -70,8 +87,13 @@ export default {
} else if (this.type == 11) { } else if (this.type == 11) {
this.$emit("getNewsIdClick", item.id); this.$emit("getNewsIdClick", item.id);
} else if (this.type == 22) { } else if (this.type == 22) {
console.log("图片放大"); this.showMask = true;
this.mask_pic = item.image;
this.mask_title = item.title;
} }
},
closeMask() {
this.showMask = false;
} }
} }
}; };
@ -99,6 +121,59 @@ export default {
} }
} }
.mask {
height: 100%;
position: fixed;
top: 0;
left: 0;
width: 100%;
background-color: #000;
opacity: 0.2;
z-index: 990;
}
.mask_pic {
position: fixed;
top: 10%;
width: 100%;
display: flex;
justify-content: center;
z-index: 991333;
opacity: 1;
.pic_bgc {
display: flex;
flex-direction: column;
padding: 35px 15px 10px 15px;
background-color: #fff;
position: relative;
.close {
position: absolute;
right: 10px;
top: 10px;
font-size: 28px;
cursor: pointer;
}
img {
width: 480px;
height: 100%;
}
.mask_info {
display: block;
font-size: 16px;
overflow: hidden;
white-space: nowrap;
-o-text-overflow: ellipsis;
text-overflow: ellipsis;
text-align: center;
padding-top: 8px;
}
}
}
.bigImg { .bigImg {
height: 270px; height: 270px;
display: inline-block; display: inline-block;

View File

@ -12,8 +12,9 @@
</div> </div>
<div class="grid_right"> <div class="grid_right">
<ul> <ul>
<li :class="'pic_'+picIndex" v-for="(picItem,picIndex) in pics" :key="picItem.src"> <li :class="'pic_'+picIndex" v-for="(picItem,picIndex) in pics" :key="picItem.src"
<a :href="picItem.href"> @click.stop="handleChangeMenu(picItem)">
<a>
<span class="pics"> <span class="pics">
<img :src="picItem.src" alt=""/> <img :src="picItem.src" alt=""/>
</span> </span>
@ -27,35 +28,55 @@
</template> </template>
<script> <script>
import {getPublicData} from "@/api";
export default { export default {
name: "ProductsClassify", name: "ProductsClassify",
data() { data() {
return { return {
pics: [ pics: [
{ {
href: '', id: 1,
src: require('../assets/index/product1.png'), src: require("../assets/index/product1.png"),
name: '瓷抛大理石' name: ""
}, },
{ {
href: '', id: 2,
src:require('../assets/index/product2.jpg'), src: require("../assets/index/product2.jpg"),
name: '通体大理石' name: ""
}, },
{ {
href: '', id: 3,
src: require('../assets/index/product3.jpg'), src: require("../assets/index/product3.jpg"),
name: '中板通体大理石' name: ""
}, },
{ {
href: '', id: 4,
src: require('../assets/index/product4.jpg'), src: require("../assets/index/product4.jpg"),
name: '大板通体大理石' name: ""
} }
] ]
};
},
created() {
getPublicData().then(res => {
this.pics[0].name = res.data.goodscategory_list[0].name;
this.pics[1].name = res.data.goodscategory_list[1].name;
this.pics[2].name = res.data.goodscategory_list[2].name;
this.pics[3].name = res.data.goodscategory_list[3].name;
});
},
methods: {
handleChangeMenu(item) {
this.$router.push({
path: "/products_center", //
query: { //
menu: item.id
}
});
} }
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
@ -63,8 +84,8 @@ export default {
.grid_box { .grid_box {
width: 1230px !important; width: 1230px !important;
} }
.pic{ .pic {
img{ img {
width: 400px !important; width: 400px !important;
} }
} }
@ -72,8 +93,8 @@ export default {
ul { ul {
li { li {
a { a {
width:360px !important; width: 360px !important;
height: 267px!important; height: 267px !important;
} }
} }
} }
@ -84,8 +105,8 @@ export default {
.grid_box { .grid_box {
width: 1100px !important; width: 1100px !important;
} }
.pic{ .pic {
img{ img {
width: 385px !important; width: 385px !important;
} }
} }
@ -93,8 +114,8 @@ export default {
ul { ul {
li { li {
a { a {
width:341px !important; width: 341px !important;
height: 258px!important; height: 258px !important;
} }
} }
} }
@ -108,6 +129,7 @@ export default {
position: relative; position: relative;
min-width: 1300px; min-width: 1300px;
display: flex; display: flex;
.grid_box { .grid_box {
width: 1360px; width: 1360px;
display: flex; display: flex;

View File

@ -12,14 +12,14 @@
</el-col> </el-col>
</el-row> </el-row>
<el-row type="flex" style="justify-content: center"> <el-row type="flex" style="justify-content: center">
<div> <div>
<el-tag <el-tag
v-for="item in tagItems" v-for="item in tagItems"
:key="item.title" :key="item.title"
effect="plain"> effect="plain">
<a :href="item.href">{{ item.name }}</a> <a @click.stop="handleChangeMenu(item)">{{ item.name }}</a>
</el-tag> </el-tag>
</div> </div>
</el-row> </el-row>
</div> </div>
</template> </template>
@ -29,39 +29,54 @@ import {getPublicData} from "@/api";
export default { export default {
name: "ProductsShow", name: "ProductsShow",
data(){ data() {
return{ return {
tagItems:[] tagItems: []
} };
}, },
created() { created() {
getPublicData().then(res => { getPublicData().then(res => {
this.tagItems = res.data.goodscategory_list; this.tagItems = res.data.goodscategory_list;
}); });
}, methods: {
handleChangeMenu(item) {
this.$router.push({
path: "/products_center", //
query: { //
menu: item.id
}
});
}
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
*{ * {
font: 14px / 1.8 微软正黑体, "Microsoft JhengHei", "Microsoft Yahei", 微软雅黑, "Hiragino Sans GB", 冬青黑体, Arial, Helvetica, SimHei, 黑体, STXihei, 华文细黑, sans-serif; font: 14px / 1.8 微软正黑体, "Microsoft JhengHei", "Microsoft Yahei", 微软雅黑, "Hiragino Sans GB", 冬青黑体, Arial, Helvetica, SimHei, 黑体, STXihei, 华文细黑, sans-serif;
} }
.el-tag:hover{
.el-tag:hover {
background-color: #333; background-color: #333;
a{
a {
color: #fff; color: #fff;
} }
} }
.el-tag:first-child{
.el-tag:first-child {
background-color: #333; background-color: #333;
a{
a {
color: #fff; color: #fff;
} }
} }
.el-tag:last-child{
.el-tag:last-child {
margin-right: 0; margin-right: 0;
} }
.el-tag { .el-tag {
border: none; border: none;
margin-right: 10px; margin-right: 10px;
@ -69,10 +84,12 @@ export default {
font-size: 15px; font-size: 15px;
height: 37px; height: 37px;
line-height: 37px; line-height: 37px;
a{
a {
color: #333; color: #333;
} }
} }
.product_show { .product_show {
min-width: 1300px; min-width: 1300px;
padding: 60px 0 60px 0; padding: 60px 0 60px 0;
@ -106,11 +123,13 @@ export default {
color: #333; color: #333;
font-size: 14px; font-size: 14px;
} }
a:hover { a:hover {
text-decoration: underline; text-decoration: underline;
} }
} }
.tagRow{
.tagRow {
text-align: center; text-align: center;
} }
} }

View File

@ -4,7 +4,7 @@
<el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col> <el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col>
<el-col :xs="22" :sm="20" :md="20" :lg="20" :xl="16"> <el-col :xs="22" :sm="20" :md="20" :lg="20" :xl="16">
<el-tabs v-if="title===1" v-model="activeName" @tab-click="handleClick"> <el-tabs v-if="title===1" v-model="activeName" @tab-click="handleClick">
<el-tab-pane v-for="(item,index) in tabList" :key="index" :label="item.title" > <el-tab-pane v-for="(item,index) in tabList" :key="index" :label="item.title">
关于我们 关于我们
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
@ -23,14 +23,14 @@
</template> </template>
<script> <script>
import {getPublicData} from "@/api";
export default { export default {
name: "TabsItem", name: "TabsItem",
props: { props: {
title: Number, title: Number,
tabList: { tabList: {
type: Array type: Array
}, productTabs: {
type: Array
}, },
fatherMethod:{ fatherMethod:{
type:Function, type:Function,
@ -39,15 +39,9 @@ export default {
}, },
data() { data() {
return { return {
activeName: '0', activeName: '0'
productTabs:[]
} }
}, },
created() {
getPublicData().then(res => {
this.productTabs=res.data.goodscategory_list
});
},
methods: { methods: {
handleClick(tab){ handleClick(tab){
if(this.fatherMethod){ if(this.fatherMethod){

View File

@ -1,12 +1,12 @@
<template> <template>
<div class="projectCase"> <div class="projectCase" id="projectCase">
<div class="case_bg"> <div class="case_bg">
<el-row> <el-row>
<div class="cases_title"> <div class="cases_title">
<h2>工程案例</h2> <h2>工程案例</h2>
<h3> Engineering Case </h3> <h3> Engineering Case </h3>
<div class="case_more"> <div class="case_more">
<a href="/image_display">查看所有</a> <a @click="changeProductCase">查看所有</a>
</div> </div>
</div> </div>
</el-row> </el-row>
@ -14,14 +14,13 @@
<el-col :xs="1" :sm="1" :md="1" :lg="3" :xl="4"></el-col> <el-col :xs="1" :sm="1" :md="1" :lg="3" :xl="4"></el-col>
<el-col :xs="22" :sm="22" :md="22" :lg="18" :xl="16"> <el-col :xs="22" :sm="22" :md="22" :lg="18" :xl="16">
<el-row type="flex"> <el-row type="flex">
<el-col class="case_example" :span="6" v-for="(item,index) in projectList" :key="index"> <el-col class="case_example" :span="6" v-for="(item,index) in projectList" :key="index" >
<ul> <ul>
<li> <li @click="handleClickNews(item)">
<div class="pics"> <div class="pics">
<el-image <el-image
class="img" class="img"
:src="item.image" :src="item.image">
:preview-src-list="item.bigSrc">
</el-image> </el-image>
</div> </div>
<div class="case_info">{{ item.title }}</div> <div class="case_info">{{ item.title }}</div>
@ -31,6 +30,19 @@
</el-row> </el-row>
</el-col> </el-col>
</el-row> </el-row>
<div v-show="showMask">
<div class="mask">
</div>
<div class="mask_pic">
<div class="pic_bgc">
<div>
<i class="el-icon-close close" @click="closeMask"></i>
<img :src="mask_pic" alt=""/>
</div>
<span class="mask_info">{{ mask_title }}</span>
</div>
</div>
</div>
</div> </div>
</div> </div>
</template> </template>
@ -42,7 +54,10 @@ export default {
name: "Projects", name: "Projects",
data() { data() {
return { return {
projectList: [] projectList: [],
showMask: false,
mask_pic: "",
mask_title: ""
} }
}, },
created() { created() {
@ -52,12 +67,86 @@ export default {
limit: 8 limit: 8
}).then(res => { }).then(res => {
this.projectList = res.data.list; this.projectList = res.data.list;
if(res.data.list.length>4){
const bg= document.getElementById('projectCase')
bg.style="margin-bottom: 300px!important;"
}
}); });
},
methods:{
closeMask() {
this.showMask = false;
},
handleClickNews(item){
this.showMask = true;
this.mask_pic = item.image;
this.mask_title = item.title;
},
changeProductCase(){
this.$router.push({
path: "/image_display", //
query: { //
menu: 8
}
});
}
} }
} }
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
.mask {
height: 100%;
position: fixed;
top: 0;
left: 0;
width: 100%;
background-color: #000;
opacity: 0.3;
z-index: 990;
}
.mask_pic {
position: fixed;
top: 10%;
width: 100%;
display: flex;
justify-content: center;
z-index: 991333;
opacity: 1;
.pic_bgc {
display: flex;
flex-direction: column;
padding: 35px 15px 10px 15px;
background-color: #fff;
position: relative;
.close {
position: absolute;
right: 10px;
top: 0;
font-size: 28px;
cursor: pointer;
}
img {
width: 480px;
height: 100%;
}
.mask_info {
display: block;
font-size: 16px;
overflow: hidden;
white-space: nowrap;
-o-text-overflow: ellipsis;
text-overflow: ellipsis;
text-align: center;
padding-top: 8px;
}
}
}
.el-row--flex { .el-row--flex {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
@ -68,11 +157,10 @@ export default {
} }
.projectCase { .projectCase {
min-height: 900px; //margin-bottom: 100px;
.case_bg { .case_bg {
min-width: 1300px; min-width: 1300px;
background: #ffffff url('http://www.yipengtaoci.com/images/cbg0.jpg') no-repeat center 0; background: #ffffff url('../assets/index/cbg0.jpg') no-repeat center 0;
background-size: cover; background-size: cover;
height: 540px; height: 540px;

View File

@ -5,7 +5,7 @@
<img src="../../assets/aboutus.jpg" alt=""/> <img src="../../assets/aboutus.jpg" alt=""/>
</div> </div>
<!--标签栏 --> <!--标签栏 -->
<ProductsTabsItem :tab-list="aboutTabs" :title="1" :fatherMethod="handleClick"/> <ProductsTabsItem :tab-list="aboutTabs" :title="1" :fatherMethod="handleClick" ref="ProductsTabsItem"/>
<!-- 关于我们的内容--> <!-- 关于我们的内容-->
<el-row type="flex"> <el-row type="flex">
<el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col> <el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col>
@ -29,28 +29,56 @@ export default {
return { return {
aboutTabs: [], aboutTabs: [],
pList: [] pList: []
};
},
watch:{
$route(to){
for (let i = 0; i < this.aboutTabs.length; i++) {
if (this.aboutTabs[i].id ==to.query.menu ) {
this.$refs.ProductsTabsItem.activeName= i+'';
}
}
getArticleInfo(to.query.menu).then(res => {
this.aboutTabs = res.data.articlelist;
this.pList = res.data.articleinfo.content;
});
}
},
beforeUpdate() {
for (let i = 0; i < this.aboutTabs.length; i++) {
if (this.aboutTabs[i].id ==this.$route.query.menu ) {
this.$refs.ProductsTabsItem.activeName= i+'';
}
} }
}, },
mounted() { mounted() {
// if(this.$route.query.menu){
getArticleInfo(1).then(res => { //
this.aboutTabs = res.data.articlelist; getArticleInfo(this.$route.query.menu).then(res => {
this.pList = res.data.articleinfo.content this.aboutTabs = res.data.articlelist;
}); this.pList = res.data.articleinfo.content;
});
}else {
getArticleInfo(1).then(res => {
this.aboutTabs = res.data.articlelist;
this.pList = res.data.articleinfo.content;
});
}
}, },
methods: { methods: {
handleClick(tab) { handleClick(tab) {
for (let i = 0; i < this.aboutTabs.length; i++) { for (let i = 0; i < this.aboutTabs.length; i++) {
console.log('this.aboutTabs[i].id',this.aboutTabs[i].id);
if (this.aboutTabs[i].title === tab._props.label) { if (this.aboutTabs[i].title === tab._props.label) {
getArticleInfo(this.aboutTabs[i].id).then(res => { getArticleInfo(this.aboutTabs[i].id).then(res => {
this.aboutTabs = res.data.articlelist; this.aboutTabs = res.data.articlelist;
this.pList = res.data.articleinfo.content this.pList = res.data.articleinfo.content;
}); });
} }
} }
} }
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
@ -92,7 +120,8 @@ export default {
.about_us_bg { .about_us_bg {
height: 360px; height: 360px;
img{
img {
width: 100%; width: 100%;
height: 360px; height: 360px;
object-fit: cover; object-fit: cover;

View File

@ -5,28 +5,19 @@
<img src="../../assets/join.jpg" alt=""/> <img src="../../assets/join.jpg" alt=""/>
</div> </div>
<!--标签栏 --> <!--标签栏 -->
<ProductsTabsItem :tab-list="joinTab" :fatherMethod="handleClick"/> <ProductsTabsItem :tab-list="joinTab" :fatherMethod="handleClick" ref="ProductsTabsItem"/>
<!-- 支持策略 --> <!-- 支持策略 -->
<el-row type="flex"> <el-row type="flex">
<el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col> <el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col>
<el-col :xs="22" :sm="20" :md="20" :lg="20" :xl="16"> <el-col :xs="22" :sm="20" :md="20" :lg="20" :xl="16">
<div class="support" id="support"> <div class="support">
<div class="support_title"> <div class="support_title">
支持策略 / SUPPORT STRATEGY {{classid==4?'支持策略 / SUPPORT STRATEGY':'加盟条件 / FRANCHISE CONDITIONS'}}
</div> </div>
<div style="font-size: 16px;padding-bottom: 25px"> <div style="font-size: 16px;padding-bottom: 25px">
<span v-html="supportList"></span> <span v-html="supportList"></span>
</div> </div>
</div> </div>
<!--加盟条件-->
<div class="support" id="join">
<div class="support_title">
加盟条件 / FRANCHISE CONDITIONS
</div>
<div style="font-size: 16px;padding-bottom: 25px">
<span v-html="joinList"></span>
</div>
</div>
</el-col> </el-col>
</el-row> </el-row>
</div> </div>
@ -41,49 +32,63 @@ export default {
components: {ProductsTabsItem}, components: {ProductsTabsItem},
data() { data() {
return { return {
classid:4,
joinTab: [], joinTab: [],
supportList: [], supportList: []
joinList: [ };
{text: '艺鹏瓷砖合作加盟条件:'}, },
{text: '1、有强烈的事业心、有良好的职业道德和商业道德重合同、守信誉、品行端正、实事求是、言行一致'}, watch: {
{text: '2、具有较强的资金实力有一定规模的营销场所有稳定的、高素质的营销队伍'}, $route(to) {
] for (let i = 0; i < this.joinTab.length; i++) {
if (this.joinTab[i].id == to.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
this.getInfo(to.query.menu)
}
},
beforeUpdate() {
for (let i = 0; i < this.joinTab.length; i++) {
if (this.joinTab[i].id == this.$route.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
} }
}, },
mounted() { mounted() {
// if (this.$route.query.menu) {
getArticleInfo(4).then(res => { //
this.joinTab = res.data.articlelist; this.getInfo(this.$route.query.menu)
this.supportList = res.data.articleinfo.content } else {
}); this.getInfo(4)
}
}, },
methods: { methods: {
//
getInfo(classId){
getArticleInfo(classId).then(res => {
this.joinTab = res.data.articlelist;
this.supportList = res.data.articleinfo.content;
});
},
handleClick(tab) { handleClick(tab) {
const support = document.getElementById('support'); for (let i = 0; i < this.joinTab.length; i++) {
const join = document.getElementById('join'); if (this.joinTab[i].title === tab._props.label) {
if (tab.index == 0) { this.getInfo(this.joinTab[i].id)
support.style.display = "block" }
join.style.display = "none"
} else if (tab.index == 1) {
join.style.display = "block"
support.style.display = "none"
} }
} }
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
#join {
display: none;
}
.Attract_join { .Attract_join {
min-width: 1300px; min-width: 1300px;
.Attract_join_bg { .Attract_join_bg {
height: 360px; height: 360px;
img{
img {
width: 100%; width: 100%;
height: 360px; height: 360px;
object-fit: cover; object-fit: cover;

View File

@ -27,14 +27,14 @@
<div v-if="item.children"> <div v-if="item.children">
<ul class="subNav" v-if="index==2"> <ul class="subNav" v-if="index==2">
<li v-for="(childrenItem,childrenIndex) in item.children" :key="childrenIndex"> <li v-for="(childrenItem,childrenIndex) in item.children" :key="childrenIndex">
<a :href="childrenItem.href"> <a @click.stop="handleChangeMenu(childrenItem,item)">
{{ childrenItem.name }} {{ childrenItem.name }}
</a> </a>
</li> </li>
</ul> </ul>
<ul class="subNav" v-else> <ul class="subNav" v-else>
<li v-for="(childrenItem,childrenIndex) in item.children" :key="childrenIndex"> <li v-for="(childrenItem,childrenIndex) in item.children" :key="childrenIndex">
<a :href="childrenItem.href"> <a @click.stop="handleChangeMenu(childrenItem,item)">
{{ childrenItem.title }} {{ childrenItem.title }}
</a> </a>
</li> </li>
@ -91,14 +91,14 @@ export default {
title: "新闻资讯", title: "新闻资讯",
children: [ children: [
{ {
href: "/news", id: 5,
title: "公司新闻" title: "公司新闻"
}, },
{ {
href: "", id: 6,
title: "行业动态" title: "行业动态"
}, { }, {
href: "", id: 7,
title: "瓷砖百科" title: "瓷砖百科"
} }
] ]
@ -108,19 +108,18 @@ export default {
title: "形象展示", title: "形象展示",
children: [ children: [
{ {
href: "/image_display", id: 2,
title: "资质荣誉" title: "资质荣誉"
}, },
{ {
href: "", id: 8,
title: "工程案例" title: "工程案例"
} }
] ]
}, },
{ {
href: "/attract_and_join", href: "/attract_and_join",
title: "招商加盟", title: "招商加盟"
children: []
}, },
{ {
href: "/contact_us", href: "/contact_us",
@ -135,8 +134,11 @@ export default {
this.corporate_name = res.data.corporate_name; this.corporate_name = res.data.corporate_name;
this.navList[1].children = res.data.aboutus; this.navList[1].children = res.data.aboutus;
this.navList[2].children = res.data.goodscategory_list; this.navList[2].children = res.data.goodscategory_list;
this.navList[5].children = res.data.join; for (let i = 0; i < res.data.join.length; i++) {
this.navList[6].children = res.data.contact_us; if (this.navList[5].title !== res.data.join[i].title) {
this.navList[5].children = res.data.join;
}
}
}); });
let header_bg = document.getElementById("header_bg"); let header_bg = document.getElementById("header_bg");
let search_header = document.getElementById("search_header"); let search_header = document.getElementById("search_header");
@ -160,6 +162,16 @@ export default {
that.width = window.screenWidth >= 1200; that.width = window.screenWidth >= 1200;
})(); })();
}; };
},
methods: {
handleChangeMenu(childrenItem, item) {
this.$router.push({
path: item.href, //
query: { //
menu: childrenItem.id //type
}
});
}
} }
}; };
</script> </script>

View File

@ -5,9 +5,11 @@
<img src="../../assets/image_display.jpg" alt=""/> <img src="../../assets/image_display.jpg" alt=""/>
</div> </div>
<!--标签栏 --> <!--标签栏 -->
<ProductsTabsItem :tab-list="imageDisplayTabs" :fatherMethod="handleClick"/> <ProductsTabsItem :tab-list="imageDisplayTabs" :fatherMethod="handleClick" ref="ProductsTabsItem"/>
<!--资质荣誉 22是封装图片放大的效果--> <!--资质荣誉 22是封装图片放大的效果-->
<PicturesBox :image-list="imageAndWord" :type="22"/> <PicturesBox :image-list="imageAndWord" :type="22"/>
<!--页码-->
<Pagination :currentPage="1" :total="total" :pageSize="limit" @pageChange="handleChangePage"/>
<div class="nullData" v-if="showNull"> <div class="nullData" v-if="showNull">
暂时没有数据 暂时没有数据
</div> </div>
@ -15,73 +17,110 @@
</template> </template>
<script> <script>
import Pagination from "@/components/Pagination";
import ProductsTabsItem from "@/components/ProductsTabsItem"; import ProductsTabsItem from "@/components/ProductsTabsItem";
import PicturesBox from "@/components/PicturesBox"; import PicturesBox from "@/components/PicturesBox";
import {getArticleList} from "@/api"; import {getArticleList} from "@/api";
export default { export default {
name: "index", name: "index",
components: {ProductsTabsItem,PicturesBox}, components: {ProductsTabsItem, PicturesBox,Pagination},
data() { data() {
return { return {
showNull:false, limit: 12,
total: 0,
classIndex:0,
showNull: false,
imageDisplayTabs: [ imageDisplayTabs: [
{ {
title: '资质荣誉', id: 2,
name: 'first' title: "资质荣誉"
}, },
{ {
title: '工程案例', id: 8,
name: 'second' title: "工程案例"
} }
], ],
imageAndWord: [], imageAndWord: []
};
},
watch: {
$route(to) {
for (let i = 0; i < this.imageDisplayTabs.length; i++) {
if (this.imageDisplayTabs[i].id == to.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
this.getArticleList(to.query.menu);
}
},
beforeUpdate() {
for (let i = 0; i < this.imageDisplayTabs.length; i++) {
if (this.imageDisplayTabs[i].id == this.$route.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
} }
}, },
mounted() { mounted() {
this.getArticleList(2) if (this.$route.query.menu) {
this.getArticleList(this.$route.query.menu);
} else {
this.getArticleList(2);
}
}, },
methods: { methods: {
// //
getArticleList(classId,page,limit){ getArticleList(classId, page, limit) {
getArticleList({ getArticleList({
classid: classId, classid: classId,
page: this.page, page: page,
limit: this.limit limit: limit
}).then(res => { }).then(res => {
console.log('',res);
this.imageAndWord = res.data.list; this.imageAndWord = res.data.list;
if(res.data.list.length==0){ if (res.data.list.length == 0) {
this.showNull=true this.showNull = true;
} }
}); });
}, },
handleClick(tab) { handleClick(tab) {
if(tab.index==0){ this.classIndex = parseInt(tab.index);
this.getArticleList(2) if (tab.index == 0) {
}else if(tab.index==1){ this.getArticleList(2, this.page, this.limit);
this.getArticleList(8) } else if (tab.index == 1) {
this.getArticleList(8, this.page, this.limit);
} }
} },
//
handleChangePage(value) {
if (this.classIndex == 0) {
this.getArticleList(2, value, this.limit);
} else if (this.classIndex == 1) {
this.getArticleList(8, value, this.limit);
}
},
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
* { * {
font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif; font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif;
} }
.nullData{
.nullData {
display: block; display: block;
height: 300px; height: 300px;
line-height: 300px; line-height: 300px;
text-align: center; text-align: center;
} }
.image_display { .image_display {
min-width: 1300px; min-width: 1300px;
.imageDisplay_bg { .imageDisplay_bg {
height: 360px; height: 360px;
img{
img {
width: 100%; width: 100%;
height: 360px; height: 360px;
object-fit: cover; object-fit: cover;

View File

@ -5,13 +5,13 @@
<img src="../../assets/news.jpg" alt=""/> <img src="../../assets/news.jpg" alt=""/>
</div> </div>
<!--标签栏 --> <!--标签栏 -->
<ProductsTabsItem :tab-list="newsTab" :fatherMethod="handleClick"/> <ProductsTabsItem :tab-list="newsTab" :fatherMethod="handleClick" ref="ProductsTabsItem"/>
<!--图片栏--> <div v-show="showImage">
<PicturesBox :image-list="imageAndWord" :type="11" v-show="showImage" @getNewsIdClick="getNewsId"/> <!--图片栏-->
<PicturesBox :image-list="imageAndWord" :type="11" @getNewsIdClick="getNewsId"/>
<!--页码--> <!--页码-->
<Pagination :currentPage="1" :total="total" :pageSize="limit" @pageChange="handleChangePage" v-show="showPagination"/> <Pagination :currentPage="1" :total="total" :pageSize="limit" @pageChange="handleChangePage"/>
</div>
<!--新闻详情--> <!--新闻详情-->
<detail :newsId="newsId" :classIndex="classIndex" v-if="showDetail"/> <detail :newsId="newsId" :classIndex="classIndex" v-if="showDetail"/>
<div class="nullData" v-if="showNull"> <div class="nullData" v-if="showNull">
@ -32,93 +32,116 @@ export default {
components: {Detail, PicturesBox, Pagination, ProductsTabsItem}, components: {Detail, PicturesBox, Pagination, ProductsTabsItem},
data() { data() {
return { return {
page:1, page: 1,
limit:10, limit: 12,
total:0, total: 0,
newsId:6, newsId: 6,
classIndex:0, classIndex: 0,
showDetail:false, showDetail: false,
showImage:true, showImage: true,
showPagination:true,
newsTab: [ newsTab: [
{ {
title: '公司新闻', id: 5,
name: 'first' title: "公司新闻"
}, { }, {
title: '行业动态', id: 6,
name: 'second' title: "行业动态"
}, { }, {
title: '瓷砖百科', id: 7,
name: 'third' title: "瓷砖百科"
}, }
], ],
imageAndWord: [], imageAndWord: [],
showNull:false showNull: false
}; };
}, },
watch: {
$route(to) {
for (let i = 0; i < this.newsTab.length; i++) {
if (this.newsTab[i].id == to.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
this.getArticleList(to.query.menu);
}
},
beforeUpdate() {
for (let i = 0; i < this.newsTab.length; i++) {
if (this.newsTab[i].id == this.$route.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
},
mounted() { mounted() {
this.getArticleList(5) if(this.$route.query.menuDetail){
this.getNewsId(this.$route.query.menuDetail)
}
if (this.$route.query.menu) {
this.getArticleList(this.$route.query.menu);
} else {
this.getArticleList(5);
}
}, },
methods: { methods: {
getNewsId(value){ getNewsId(value) {
this.newsId=value this.newsId = value;
if(this.newsId!==0){ if (this.newsId !== 0) {
this.showDetail=true this.showDetail = true;
this.showPagination=false this.showImage = false;
this.showImage=false
} }
}, },
// //
getArticleList(classId,page,limit){ getArticleList(classId, page, limit) {
getArticleList({ getArticleList({
classid: classId, classid: classId,
page: this.page, page: page,
limit: this.limit limit: limit
}).then(res => { }).then(res => {
this.total=res.data.count this.total = res.data.count;
this.imageAndWord = res.data.list; this.imageAndWord = res.data.list;
if(res.data.list.length==0){ if (res.data.list.length == 0) {
this.showNull=true this.showNull = true;
} }
}); });
}, },
handleClick(tab) { handleClick(tab) {
this.showDetail=false this.showDetail = false;
this.showImage=true this.showImage = true;
this.showPagination=true this.classIndex = parseInt(tab.index);
this.classIndex=parseInt(tab.index)
if (tab.index == 0) { if (tab.index == 0) {
this.getArticleList(5) this.getArticleList(5, this.page, this.limit);
} else if (tab.index == 1) { } else if (tab.index == 1) {
this.getArticleList(6) this.getArticleList(6, this.page, this.limit);
} else if (tab.index == 2) { } else if (tab.index == 2) {
this.getArticleList(7) this.getArticleList(7, this.page, this.limit);
} }
}, },
// //
handleChangePage(value){ handleChangePage(value) {
if(this.classIndex==0){ if (this.classIndex == 0) {
this.getArticleList(5,value,this.limit) this.getArticleList(5, value, this.limit);
}else if (this.classIndex == 1) { } else if (this.classIndex == 1) {
this.getArticleList(6,value,this.limit) this.getArticleList(6, value, this.limit);
} else if (this.classIndex == 2) { } else if (this.classIndex == 2) {
this.getArticleList(7,value,this.limit) this.getArticleList(7, value, this.limit);
} }
} }
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
* { * {
font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif; font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif;
} }
.nullData{
.nullData {
display: block; display: block;
height: 300px; height: 300px;
line-height: 300px; line-height: 300px;
text-align: center; text-align: center;
} }
#industry_dynamics { #industry_dynamics {
display: none; display: none;
} }
@ -146,7 +169,8 @@ export default {
.news_bg { .news_bg {
height: 360px; height: 360px;
img{
img {
width: 100%; width: 100%;
height: 360px; height: 360px;
object-fit: cover; object-fit: cover;

View File

@ -1,7 +1,5 @@
<template> <template>
<div style="min-width: 1300px"> <div style="min-width: 1300px">
<!-- 产品标签栏-->
<ProductsTabsItem :title="9" />
<div class="img_text_bgc"> <div class="img_text_bgc">
<el-row type="flex"> <el-row type="flex">
<el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col> <el-col :xs="1" :sm="2" :md="2" :lg="2" :xl="4"></el-col>
@ -66,11 +64,10 @@
<script> <script>
import ProductsTabsItem from "@/components/ProductsTabsItem"; import ProductsTabsItem from "@/components/ProductsTabsItem";
import {getGoodsInfo, getGoodsList} from "@/api"; import {getGoodsInfo, getGoodsList, getPublicData} from "@/api";
export default { export default {
name: "detail", name: "detail",
components: {ProductsTabsItem},
data() { data() {
return { return {
showNull:false, showNull:false,

View File

@ -1,7 +1,7 @@
<template> <template>
<div class="products_center"> <div class="products_center">
<!--标签栏 --> <!--标签栏 -->
<ProductsTabsItem :title="9" :fatherMethod="handleClick"/> <ProductsTabsItem :title="9" :product-tabs="productTabs" :fatherMethod="handleClick" ref="ProductsTabsItem"/>
<!-- 分类栏--> <!-- 分类栏-->
<div class="product_types"> <div class="product_types">
<el-row type="flex"> <el-row type="flex">
@ -10,19 +10,25 @@
<div class="spaceList"> <div class="spaceList">
<strong>分类</strong> <strong>分类</strong>
<ul> <ul>
<li v-for="(item,index) in classifyList" @click="changeClassify(item,index)" :id="'classify_'+index">{{ item.name }}</li> <li v-for="(item,index) in classifyList" @click.stop="changeClassify(item,index)" :id="'classify_'+index">
{{ item.name }}
</li>
</ul> </ul>
</div> </div>
<div class="spaceList"> <div class="spaceList">
<strong>空间</strong> <strong>空间</strong>
<ul> <ul>
<li v-for="(item,index) in spaceList" @click="changeSpace(item,index)" :id="'space_'+index">{{ item.title }}</li> <li v-for="(item,index) in spaceList" @click.stop="changeSpace(item,index)" :id="'space_'+index">
{{ item.title }}
</li>
</ul> </ul>
</div> </div>
<div class="spaceList"> <div class="spaceList">
<strong>风格</strong> <strong>风格</strong>
<ul> <ul>
<li v-for="(item,index) in styleList" @click="changeStyle(item,index)" :id="'style_'+index">{{ item.title }}</li> <li v-for="(item,index) in styleList" @click.stop="changeStyle(item,index)" :id="'style_'+index">
{{ item.title }}
</li>
</ul> </ul>
</div> </div>
</el-col> </el-col>
@ -30,7 +36,8 @@
</div> </div>
<!--图片栏--> <!--图片栏-->
<PicturesBox :image-list="imgList" :type="33"/> <PicturesBox :image-list="imgList" :type="33"/>
<Pagination :currentPage="1" :total="total" :pageSize="pageSize" @pageChange="handleChangePage" v-if="showPagination"/> <Pagination :currentPage="1" :total="total" :pageSize="pageSize" @pageChange="handleChangePage"
v-if="showPagination"/>
<div class="nullData" v-if="showNull"> <div class="nullData" v-if="showNull">
暂时没有数据 暂时没有数据
</div> </div>
@ -48,97 +55,181 @@ export default {
components: {PicturesBox, Pagination, ProductsTabsItem}, components: {PicturesBox, Pagination, ProductsTabsItem},
data() { data() {
return { return {
showNull:false, showNull: false,
showPagination:true, showPagination: true,
classifyList: [], classifyList: [],
spaceList: [], spaceList: [],
styleList: [], styleList: [],
pageSize:12, pageSize: 12,
total:0, total: 0,
imgList: [], imgList: [],
classIndex:'' classIndex: "",
productTabs: []
};
},
watch: {
$route(to) {
if (to.query.menu) {
for (let i = 0; i < this.productTabs.length; i++) {
if (this.productTabs[i].id == to.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
getGoodsCategory(to.query.menu).then(res => {
this.classifyList = res.data.categorylist;
});
//
getGoodsList({
classid: to.query.menu,
page: 1,
limit: this.pageSize
}).then(res => {
this.total = res.data.count;
this.imgList = res.data.list;
});
}
}
},
beforeUpdate() {
if (this.$route.query.menu) {
for (let i = 0; i < this.productTabs.length; i++) {
if (this.productTabs[i].id == this.$route.query.menu) {
this.$refs.ProductsTabsItem.activeName = i + "";
}
}
}
if (this.$route.query.menuTitle) {
for (let i = 0; i < this.classifyList.length; i++) {
const red = document.getElementById("classify_" + i);
if (this.classifyList[i].name == this.$route.query.menuTitle) {
red.style = "color: #f00!important;text-decoration: underline!important;";
} else {
red.style = "color: #000!important;";
}
}
for (let i = 0; i < this.spaceList.length; i++) {
const red = document.getElementById("space_" + i);
if (this.spaceList[i].title == this.$route.query.menuTitle) {
red.style = "color: #f00!important;text-decoration: underline!important;";
} else {
red.style = "color: #000!important;";
}
}
for (let i = 0; i < this.styleList.length; i++) {
const red = document.getElementById("style_" + i);
if (this.styleList[i].title == this.$route.query.menuTitle) {
red.style = "color: #f00!important;text-decoration: underline!important;";
} else {
red.style = "color: #000!important;";
}
}
} }
}, },
mounted() { mounted() {
getPublicData().then(res => {
this.productTabs = res.data.goodscategory_list;
});
// //
getPublicData().then(res => { getPublicData().then(res => {
this.spaceList = res.data.space_list this.spaceList = res.data.space_list;
this.styleList = res.data.style_list this.styleList = res.data.style_list;
});
//,
getGoodsCategory(1).then(res => {
this.classifyList = res.data.categorylist
});
//
getGoodsList({
classid:0,
page:1,
limit:this.pageSize,
}).then(res => {
this.total=res.data.count
this.imgList=res.data.list
}); });
if (this.$route.query.menu) {
//,
getGoodsCategory(this.$route.query.menu).then(res => {
this.classifyList = res.data.categorylist;
});
this.getGoodsList(this.$route.query.menu, 1, this.pageSize);
} else {
//,
getGoodsCategory(1).then(res => {
this.classifyList = res.data.categorylist;
});
this.getGoodsList(0, 1, this.pageSize);
}
}, },
methods: { methods: {
// //
getGoodsList(classid,page,limit,stylename,spacename){ getGoodsList(classid, page, limit, stylename, spacename) {
getGoodsList({ getGoodsList({
classid:classid, classid: classid,
page:page, page: page,
limit:limit, limit: limit,
stylename:stylename, stylename: stylename,
spacename:spacename, spacename: spacename
}).then(res => { }).then(res => {
this.total=res.data.count this.total = res.data.count;
this.imgList=res.data.list this.imgList = res.data.list;
if(res.data.list.length===0){ if (res.data.list.length === 0) {
this.showNull=true this.showNull = true;
this.showPagination=false this.showPagination = false;
} }
}); });
}, },
// //
handleClick(tab) { handleClick(tab) {
let index = parseInt(tab.index) + 1 let index = parseInt(tab.index) + 1;
this.classIndex=index this.classIndex = index;
getGoodsCategory(index).then(res => { getGoodsCategory(index).then(res => {
this.classifyList = res.data.categorylist this.classifyList = res.data.categorylist;
}); });
this.getGoodsList(index,1,this.pageSize) this.getGoodsList(index, 1, this.pageSize);
}, },
// //
handleChangePage(value){ handleChangePage(value) {
this.getGoodsList(this.classIndex,value,this.pageSize) this.getGoodsList(this.classIndex, value, this.pageSize);
}, },
//, //,
changeClassify(item,index){ changeClassify(item) {
this.getGoodsList(item.id,1,this.pageSize) this.$router.push({
document.getElementById('classify_'+index).style="color: #f00;text-decoration: underline;" path: "/products_center",
query: {
menuTitle: item.name
}
});
this.getGoodsList(item.id, 1, this.pageSize);
}, },
//, //,
changeSpace(item,index){ changeSpace(item) {
this.getGoodsList(this.classIndex,1,this.pageSize,'',item.title) this.$router.push({
document.getElementById('space_'+index).style="color: #f00;text-decoration: underline;" path: "/products_center",
query: {
menuTitle: item.title
}
});
this.getGoodsList(this.classIndex, 1, this.pageSize, "", item.title);
}, },
//, //,
changeStyle(item,index){ changeStyle(item) {
this.getGoodsList(this.classIndex,1,this.pageSize,item.title,'') this.$router.push({
document.getElementById('style_'+index).style="color: #f00;text-decoration: underline;" path: "/products_center",
query: {
menuTitle: item.title
}
});
this.getGoodsList(this.classIndex, 1, this.pageSize, item.title, "");
} }
} }
} };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
* { * {
font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif; font: 14px/1.8 "微软正黑体", "Microsoft JhengHei", "Microsoft Yahei", "微软雅黑", "Hiragino Sans GB", "冬青黑体", "Arial", "Helvetica", "SimHei", "黑体", "STXihei", "华文细黑", sans-serif;
} }
.nullData{
.becomeRed {
color: #f00;
text-decoration: underline;
}
.nullData {
display: block; display: block;
height: 300px; height: 300px;
line-height: 300px; line-height: 300px;
text-align: center; text-align: center;
} }
.products_center { .products_center {
min-width: 1300px; min-width: 1300px;