dengrui/pages/tabbar/product/product.vue

400 lines
13 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<template>
<view v-if="pageShow">
<!-- 使用标题栏 -->
<status-nav @inputConfirm="inputConfirm" :statusBackg="true" :statusInput="true" :whereCome="whereCome*1" :backgroudColor="'#ffffff'" :tabcolor="'#ffffff'"></status-nav>
<!-- 导航 -->
<view class="disaa color33 bacb zIn1 ptab" :style="{top:statusHNH+'px'}">
<view :class="current==0?'bold':''" @tap="choose(0)">综合推荐</view>
<view :class="current==1?'bold':''" @tap="choose(1)">销量</view>
<view :class="current==2?'bold':''" @tap="choose(2)" class="disac">
<view>价格</view>
<view class=" margin-z10">
<view v-if="showJian" class="discc">
<image class="ascedesc" src="/static/img/product/ascendingOrder.png"></image>
<image class="ascedesc" style="transform: rotateZ(180deg);" src="/static/img/product/ascendingOrder.png"></image>
</view>
<view v-else class="discc">
<image v-if="!isasce" @tap.stop="asecedescEvent(0)" class="ascedesc" src="/static/img/product/ascendingOrder.png"></image>
<image v-else class="ascedesc" style="transform: rotateZ(180deg);" src="/static/img/product/descendingOrder.png"></image>
<image v-if="isasce" @tap.stop="asecedescEvent(1)" class="ascedesc" style="transform: rotateZ(180deg);" src="/static/img/product/ascendingOrder.png"></image>
<image v-else class="ascedesc" src="/static/img/product/descendingOrder.png"></image>
</view>
</view>
</view>
<view :class="chooseShai?'catebold':''" @tap="chooseShaiEv" class="disac">
<view>筛选</view>
<!-- 筛选图标 -->
<image v-if="chooseShai" style="width: 22rpx;height: 22rpx;" src="/static/img/product/screen_02.png"></image>
<image v-else style="width: 22rpx;height: 22rpx;" src="/static/img/product/screen.png"></image>
</view>
</view>
<!-- 列表 -->
<view class="padding20 bacb plist" v-if="productList.length!=0" :style="{marginTop:(statusHNH+42)+'px'}">
<view @tap="goDetail(item.spu_id)" class="disba padding-x30 padding-s20 borbot margin-s10" v-for="(item,index) in productList" :key="index">
<image class="proimg flexs radius10" :src="item.src"></image>
<view class="padding-sx20 padding-z20 width100">
<view class="clips2 fon28">{{item.title}}</view>
<view class="fon24 color9 margin-sx10 clips1">{{item.content}}</view>
<view class="dis flw">
<label class="colorf6 fon24 radius16 pro margin-y10" v-for="(itemc,indexc) in item.cate" :key="indexc">{{itemc.name}}</label>
</view>
<view class="disba margin-s20">
<view class="colorf6 fon24 bold"><text class="fon28">{{item.price}}</text>.0</view>
<!-- 加入购物车图片 -->
<image v-if="user_type!='personal'" @tap.stop="addGou(item.id)" class="progc" src="/static/img/public/gouwcar.png"></image>
</view>
</view>
</view>
</view>
<view v-if="productList.length==0" class="zanwu">暂无相关产品</view>
<!-- 筛选弹框 -->
<view v-if="yin" :class="isShai?'fadeInRight':chuout+' '+xiao" class="pchoose animated" :style="{top:(statusHNH+32)+'px'}">
<view class="padding-sx20" style="display: flex;background-color: rgba(0,0,0,.3);flex-direction: row-reverse;">
<!-- 筛选弹框,关闭图片 -->
<image @tap="closeCate" class="margin-y20" style="width: 28rpx;height: 28rpx;" src="/static/img/product/pclose.png" mode=""></image>
</view>
<view class="dis" style="height: 100%;">
<scroll-view v-if="shaiArrt.length!=0" scroll-y style="background-color: #FFFFFF;height: 100%;">
<view>
<view @tap="checkShait(item.id,indexs)"
:class="shaiCurrentt==indexs?'dangShait colorb':'xbort color6'"
class="fon24 disac shaiEnd" v-for="(item,indexs) in shaiArrt"
:key="indexs" style="padding: 30rpx;">
<view class="flexs ">{{item.name}}</view>
</view>
</view>
</scroll-view>
<scroll-view scroll-y style="background-color: #f5f5f5;height: 100%;">
<view>
<view @tap="checkShai(item.id,indexs)"
:class="shaiCurrent==indexs?'dangShai':''"
class="fon24 disac shaiEnd" v-for="(item,indexs) in shaiArr"
:key="indexs" style="padding: 30rpx;">
<view class="flexs">{{item.name}}</view>
<!-- 筛选弹框,右侧图片 -->
<image v-if="shaiCurrent==indexs" class="posia" style="right: 0;width: 4rpx;height: 49rpx;" src="/static/img/product/pyxian.png" mode=""></image>
</view>
</view>
</scroll-view>
</view>
</view>
<backTop :showTop="showTop" @backTop="backTop"></backTop>
</view>
</template>
<script>
import backTop from '@/components/backTop.vue';
export default {
components:{
backTop
},
data() {
return {
current:0,
chooseShai:false,
isasce:true,
productList:[],
zanList:[],//暂存产品列表不显示
shaiArr:[],
shaiArrt:[],
shaiCurrent:0,
shaiCurrentt:'-1',
isShai:false,
yin:false,
chuout:'',
xiao:'',
showTop:false,
whereCome:2,
page:1,
size:10,
total:'',
isZanw:true,
cid:0,//分类ID
filed:'',//默认synthetical 取值view_amount、sale_amount、sort_price
direction:'down',//取值down/up
statusHNH:uni.getStorageSync('statusHNH'),
moIndex:0,
pageShow:false,
showJian:true,
user_type:uni.getStorageSync('user_type')//权限
}
},
onShow() {
this.$toolAll.tools.guoq()
uni.showTabBar()
uni.getStorageSync('whereCome') !='' ? this.whereCome = uni.getStorageSync('whereCome') : ''
uni.removeStorageSync('proDetail')
// console.log('清除产品详情缓存成功',uni.getStorageSync('proDetail'));
this.showJian = true
this.isasce = true
this.moIndex = 0
this.direction = 'up'
this.current = 0
this.filed = 'synthetical'
this.cid = 0
this.size = 10
this.page = 1
this.checkList()
},
onReachBottom() {
console.log(this.total,this.productList.length);
if(this.total!=this.productList.length){
this.page++
this.checkList()//调用自主预约列表事件
} else {
if(this.isZanw) this.$toolAll.tools.showToast('暂无更多商品列表','none',1000)
this.isZanw = false
}
},
onLoad() {
this.shaiEv()
},
onPageScroll(e) {
e.scrollTop > 360 ? this.showTop = true : this.showTop = false
},
// onReachBottom() {
// console.log('触底了');
// let that = this;
// this.page++
// that.checkList();
// },
methods: {
checkList(){
let paramCate ={
category_id:this.cid,
page:this.page,
size:this.size,
sort_filed:this.filed,
sort_direction:this.direction
}
// console.log('参数:',paramCate);
this.$requst.post('product/spu/list',paramCate).then(res=>{
// console.log('产品',res);
if(res.code==0){
this.pageShow = true
if(this.page==1) this.productList = []
this.total = res.data.total
if(res.data.list.length!=0){
// this.cid = res.data.list[0].cid//获取分类ID以便加载更多使用
this.zanList = res.data.list
res.data.list.forEach(item=>{
let cateObj = {
id:item.main_sku.id,//商品ID
spu_id:item.id,
src:this.$http + item.main_sku.main_image,//商品图片
title:item.name,//商品名称
content:item.sub_title,//商品标题
cate:item.tag_list,//标签列表
price:item.main_sku.cur_price/100//商品原价
}
this.productList.push(cateObj)
})
} else {
// this.$toolAll.tools.showToast('没找到相关产品o(╥﹏╥)o')
}
}
},error=>{})
},
inputConfirm(e){
// console.log(e);
this.keySearch(e)
},
keySearch(key){
this.productList = []
if(key!='' || key=='') this.cid = ''
let paramCate ={
category_id:this.cid,
page:this.page,
size:this.size,
sort_filed:this.filed,
sort_direction:this.direction,
keyword:key
}
this.$requst.post('product/spu/list',paramCate).then(res=>{
// console.log('产品',res);
if(res.data.list.length!=0){
this.cid = res.data.list[0].cid//获取分类ID以便加载更多使用
this.zanList = res.data.list
res.data.list.forEach(item=>{
let cateObj = {
id:item.id,//商品ID
src:this.$http + item.main_sku.main_image,//商品图片
title:item.name,//商品名称
content:item.sub_title,//商品标题
cate:item.tag_list,//标签列表
price:item.main_sku.cur_price/100//商品原价
}
this.productList.push(cateObj)
})
} else {
// this.$toolAll.tools.showToast('没找到相关产品o(╥﹏╥)o')
}
},error=>{})
},
backTop(){//回到顶部事件
uni.pageScrollTo({
scrollTop: 0,
duration: 300
});
this.isShai = false
},
choose(index){//标题选择
let ya = this
this.shaiCurrent = '-1'
this.shaiCurrentt = '-1'
this.cid = 0
this.page = 1
this.size = 10
this.current = index
if(index==0){this.filed = 'synthetical'}
else if(index==1){this.filed = 'sale_amount';this.direction = 'down'}
else if(index==2){//价格点击事件判断
this.showJian = false
this.moIndex++
if(this.moIndex==1){
// console.log('2');
if(!this.isasce){
this.direction = 'down'
} else this.direction = 'up'
} else {
// console.log('3');
this.isasce = !this.isasce
if(!this.isasce){
this.direction = 'down'
} else {
this.direction = 'up'
}
}
this.filed = 'sort_price';this.checkList();return false
} else {
this.isShai = false
this.hideEv()
return false
}
this.checkList()
},
chooseShaiEv(){
this.cid = 0
this.page = 1
this.size = 10
this.yin = true
this.isShai= true
this.chooseShai = true
this.chuout='fadeOutRight'
},
closeCate(){//关闭按钮事件
this.isShai = false
this.hideEv()
},
hideEv(){//隐藏筛选弹框延迟事件
let ya = this
setTimeout(function(){
ya.yin = false
},500)
},
shaiEv(){//商品分类查询事件
this.$requst.post('product/spu/category').then(res=>{
// console.log('筛选',res);
if(res.data.length!=0){
res.data.forEach(item=>{
let obj = {
id:item.id,
name:item.name,
pid:item.pid,
hasChildren:item.hasChildren,
children:item.children
}
this.shaiArr.push(obj)
})
if(this.shaiArr[0].children.length!=0 && this.shaiArr[0].children!=undefined){
this.shaiArr[0].children.forEach(item=>{
let obj = {
id:item.id,
name:item.name,
pid:item.pid,
hasChildren:item.hasChildren,
}
this.shaiArrt.push(obj)
})
}
}
},error=>{})
},
asecedescEvent(index){//升序
this.cid = 0
this.page = 1
this.size = 10
this.current = 2
if(index==0){
this.isasce = false
this.direction = 'up'
} else {
this.isasce = true
this.direction = 'down'
}
this.checkList()
},
addGou(e){//加入购物车
// console.log('加入购物车'+e);
// uni.showToast({title:'加入购物车'+e+'成功',icon:'none'})
if(uni.getStorageSync('is_active')==0) {
this.$toolAll.tools.showToast('您目前是游客,请授权登录')
setTimeout(()=>{
uni.navigateTo({url:'/pages/login/login'})
},1500)
} else {
this.$requst.post('order/shopping-cart-add',{sku_id:e,num:1}).then(res=>{
if(res.code==0){
this.$toolAll.tools.showToast('添加购物车成功(*^▽^*)')
}
},error=>{})
}
},
goDetail(id){//查看详情
// console.log(id);
uni.navigateTo({
url:'/pagesA/productDetail/productDetail?id='+id
})
},
checkShai(id,index){//筛选框item点击事件 按类别查询商品
// console.log(id,index);
this.shaiCurrent = index
this.shaiCurrentt = '-1'
if(id=='') this.cid = 0
else this.cid = id
this.page = 1
this.isZanw = true
this.checkList()
this.shaiArrt = []
if(this.shaiArr[index].hasChildren==true && this.shaiArr[index].children.length!=0){
this.shaiArr[index].children.forEach(item=>{
let obj = {
id:item.id,
name:item.name,
pid:item.pid,
hasChildren:item.hasChildren,
}
this.shaiArrt.push(obj)
})
}
},
checkShait(id,index){
this.shaiCurrentt = index
if(id=='') this.cid = 0
else this.cid = id
this.page = 1
this.isZanw = true
this.checkList()
}
},
onHide() {
this.isShai = false
this.yin = false
}
}
</script>
<style>
page {background-color: #f5f5f5;}
</style>