店铺二级分类修改

This commit is contained in:
DESKTOP-GMUNQ1B\k 2024-04-24 15:14:34 +08:00
parent 738de8ccb6
commit eaacdabdc4
4 changed files with 744 additions and 583 deletions

1069
App.vue

File diff suppressed because it is too large Load Diff

View File

@ -522,18 +522,26 @@
diyId: 0, diyId: 0,
preview: false, preview: false,
isSupport: true, isSupport: true,
isIndexClick: true,
scrollTop: 0
}; };
}, },
onTabItemTap(e) { onTabItemTap(e) {
uni.pageScrollTo({ if (this.isIndexClick) {
scrollTop: 0, uni.pageScrollTo({
duration: 300 scrollTop: 0,
}); duration: 300
});
} else {
this.isIndexClick = true;
}
}, },
// //
onPageScroll(e) { onPageScroll(e) {
this.isIndexClick = true;
this.scrollTop = e.scrollTop;
this.isFixed = e.scrollTop > 40; this.isFixed = e.scrollTop > 40;
if (this.isHeaderSerch) { if (this.isHeaderSerch) {
let isScroll = false let isScroll = false
@ -545,7 +553,6 @@
// scrollTopeasy-loadimage // scrollTopeasy-loadimage
uni.$emit('scroll'); uni.$emit('scroll');
if (e.scrollTop >= 100) { if (e.scrollTop >= 100) {
uni.setTabBarItem({ uni.setTabBarItem({
index: 0, index: 0,
@ -612,7 +619,8 @@
this.activeRouter = '/' + curRoute this.activeRouter = '/' + curRoute
}, },
onShow() { onShow() {
let that = this let that = this;
that.isIntegral = uni.getStorageSync('isIntegral') that.isIntegral = uni.getStorageSync('isIntegral')
// #ifdef APP-PLUS // #ifdef APP-PLUS
if (that.appUpdate.openUpgrade == '1') { if (that.appUpdate.openUpgrade == '1') {
@ -628,6 +636,8 @@
that.isScrolled = res[0].top <= -60 that.isScrolled = res[0].top <= -60
}) })
}) })
this.isIndexClick = false;
if (this.isLogin) { if (this.isLogin) {
this.getUserInfo(); this.getUserInfo();
} }

View File

@ -2,7 +2,6 @@
<view class="store-home"> <view class="store-home">
<view class="header"> <view class="header">
<view style="height: var(--status-bar-height);"></view> <view style="height: var(--status-bar-height);"></view>
<view class="head-menu"> <view class="head-menu">
<view class="iconfont icon-xiangzuo" @click="goback" style="color: #fff;"></view> <view class="iconfont icon-xiangzuo" @click="goback" style="color: #fff;"></view>
<navigator :url="'/pages/store/list/index?mer_id='+id" hover-class="none" <navigator :url="'/pages/store/list/index?mer_id='+id" hover-class="none"
@ -86,10 +85,10 @@
</view> </view>
<scroll-view class="main" scroll-y="true" @scroll="scrollHome" catchtouchmove :style="viewColor"> <scroll-view class="main" scroll-y="true" @scroll="scrollHome" catchtouchmove :style="viewColor">
<!-- nav的占位 -->
<view class="tab-cont" <view class="tab-cont"
:style="viewColor,{'height':'calc(100vh - '+listHeight + (tabActive == 2?' + 84rpx':'')+' )'}" :style="viewColor,{'height':'calc(100vh - '+(listHeight) + (tabActive == 2?' + 84rpx':'')+' )'}"
:class="{noPointer : preview}"> :class="{noPointer : preview}">
<!-- 占位 --> <!-- 占位 -->
<view class="aside-left-placeholder" v-if="tabActive != 2"></view> <view class="aside-left-placeholder" v-if="tabActive != 2"></view>
@ -151,11 +150,28 @@
</view> </view>
<!-- 首页 --> <!-- 首页 -->
<view style="margin:0 auto;" <view style="margin:0px auto;"
v-show="(tabActive == 3 || tabActive == 7 || diyActive == 1 || diyActive == 2) && tabActive != 5 && tabActive != 2"> v-show="(tabActive == 3 || tabActive == 7 || diyActive == 1 || diyActive == 2) && tabActive != 5 && tabActive != 2">
<!-- 二级分类 -->
<scroll-view :scroll-x="true" class="small-classify" :style="{'width':'calc(100vw - 152rpx)'}"
v-if="asideCurr">
<view class="second-item-con-wrap">
<view class="second-item-con" :style="{'flex-wrap':isChangeSecTabStyle?'wrap':''}">
<block v-for="item in secondTabList" :key="item.store_category_id">
<view class="small-classify-item"
:class="{'small-classify-item-active':secondTabCurr == item.store_category_id?true:false}"
@click="onSecondTabChange(item.store_category_id)">
{{item.cate_name}}
</view>
</block>
</view>
<view class="sanjiaoxing" @click="onChangeSecTabStyle"></view>
</view>
</scroll-view>
<!-- 商品 --> <!-- 商品 -->
<view v-if="goods.length" class="goods-wrap" id="goods" @touchmove="onTouchmove" <view v-if="goods.length" class="goods-wrap" id="goods" @touchmove="onTouchmove"
:style="{'width':'calc(100vw - 152rpx)'}"> :style="{'width':'calc(100vw - 152rpx)','padding-top':(!!asideCurr?'94rpx' :'')}">
<view v-if="isColumn" class="goods column"> <view v-if="isColumn" class="goods column">
<view v-for="(item,indx) in goods" :key="indx" class="item" @click="goGoodsDetail(item)"> <view v-for="(item,indx) in goods" :key="indx" class="item" @click="goGoodsDetail(item)">
<view class="image" style="width: 180rpx;height: 180rpx;"> <view class="image" style="width: 180rpx;height: 180rpx;">
@ -197,7 +213,8 @@
<WaterfallsFlow :wfList='goods' @itemTap="goGoodsDetail" :type="1" :isStore="1" /> <WaterfallsFlow :wfList='goods' @itemTap="goGoodsDetail" :type="1" :isStore="1" />
</view> </view>
</view> </view>
<view v-if="goodsLoading" class="acea-row row-center-wrapper loadingicon"> <view v-if="goodsLoading" class="acea-row row-center-wrapper loadingicon"
:style="{'margin-top':!!asideCurr?'94rpx':''}">
<text :hidden="!goodsLoading" class="iconfont icon-jiazai loading"></text> <text :hidden="!goodsLoading" class="iconfont icon-jiazai loading"></text>
{{loadTitle}} {{loadTitle}}
</view> </view>
@ -224,7 +241,8 @@
</view> </view>
</view> </view>
</view> </view>
<view class="acea-row row-center-wrapper loadingicon"> <view class="acea-row row-center-wrapper loadingicon"
:style="{'margin-top':!!asideCurr?'94rpx':''}">
<text :hidden="!categoryLoading" class="iconfont icon-jiazai loading"></text> <text :hidden="!categoryLoading" class="iconfont icon-jiazai loading"></text>
{{loadTitle}} {{loadTitle}}
</view> </view>
@ -373,7 +391,7 @@
navShow: false, navShow: false,
navActive: 0, navActive: 0,
diyActive: 0, diyActive: 0,
tabActive: '', // tabActive: 3, //
isCoupon: 0, isCoupon: 0,
keyword: '', keyword: '',
order: '', order: '',
@ -470,7 +488,11 @@
asideCurr: '', asideCurr: '',
CartCount: 0, CartCount: 0,
navHeight: 0, navHeight: 0,
listTop: 0 listTop: 0,
mer_type: '', //
secondTabList: [],
secondTabCurr: '', //
isChangeSecTabStyle: false
} }
}, },
computed: { computed: {
@ -527,6 +549,7 @@
break; break;
case 7: case 7:
this.resetParmas(); this.resetParmas();
this.getMerClassifly();
this.goods = []; this.goods = [];
this.getGoods(); this.getGoods();
break; break;
@ -557,8 +580,9 @@
} }
} }
// #endif // #endif
//
this.getStore(); this.getStore();
this.diyData(); // this.diyData();
shareScence(this.currSpid, this.isLogin); shareScence(this.currSpid, this.isLogin);
this.initHeight(); this.initHeight();
@ -579,6 +603,8 @@
}) })
this.getMerClassifly(); this.getMerClassifly();
//
this.getCart(); this.getCart();
}, },
@ -617,31 +643,99 @@
getCartCounts({ getCartCounts({
sale_type: this.where.sale_type sale_type: this.where.sale_type
}).then(res => { }).then(res => {
console.log(res)
that.CartCount = res.data[0].count; that.CartCount = res.data[0].count;
}); });
}, },
// //
onChangeAsideMenu(e) { onChangeAsideMenu(e) {
//
this.getMerClassifly(e)
this.asideCurr = e; this.asideCurr = e;
this.resetParmas(); this.resetParmas();
this.goods = []; this.goods = [];
this.loadend = false; this.loadend = false;
//
this.secondTabCurr = '';
this.isChangeSecTabStyle = false;
},
//
getMerClassifly(pid) {
const param = {
mer_type: 2,
sale_type: this.where.sale_type,
mer_id: '',
mer_type: '',
pid: pid
};
// ()
if (this.tabActive == 7) {
param.mer_type = 1;
param.mer_id = '';
}
//()
if (this.tabActive == 3) {
param.mer_id = this.id;
param.mer_type = 2;
}
getCategoryIndexList(param).then(res => {
//
if (pid) {
this.secondTabList = [{
cate_name: '全部',
store_category_id: ''
}, ...res.data];
} else { //
this.asideMenu = [{
cate_name: '全部',
store_category_id: ''
}, ...res.data];
}
this.getGoods();
})
},
//
onSecondTabChange(e) {
this.isChangeSecTabStyle = false;
this.secondTabCurr = e;
this.resetParmas();
this.goods = [];
this.loadend = false;
this.getGoods(); this.getGoods();
}, },
// //
getMerClassifly() { tab: function(param) {
getCategoryIndexList({ if (param == 9) return uni.switchTab({
mer_type: 2, url: "/pages/order_addcart/order_addcart"
sale_type: this.where.sale_type });
}).then(res => {
this.asideMenu = [{ this.tabActive = param;
cate_name: '全部', this.goodsLoading = this.loadend = this.loading = false;
store_category_id: ''
}, ...res.data]; // tab
}) this.secondTabCurr = '';
this.secondTabList = [];
this.asideCurr = '';
this.asideMenu = [];
this.loadend = false;
this.getMerClassifly();
},
//
onChangeSecTabStyle() {
this.isChangeSecTabStyle = !this.isChangeSecTabStyle;
},
// navbar
scrollHome: function(e) {
console.log(1)
// uni.$emit('scroll');
// this.navShow = e.detail.scrollTop >= 50;
}, },
navTo(url) { navTo(url) {
@ -862,7 +956,6 @@
}, },
// //
getGoods: function() { getGoods: function() {
console.log(2)
let that = this; let that = this;
if (that.loadend) return; if (that.loadend) return;
if (that.loading) return; if (that.loading) return;
@ -870,7 +963,11 @@
that.goodsLoading = true; that.goodsLoading = true;
that.loadTitle = ''; that.loadTitle = '';
that.where.cate_pid = that.asideCurr;
if (that.secondTabCurr) //
that.where.cate_pid = that.secondTabCurr;
else //
that.where.cate_pid = that.asideCurr;
if (this.tabActive == 7) getStoreCloudGoods(that.id, that.where).then(res => { if (this.tabActive == 7) getStoreCloudGoods(that.id, that.where).then(res => {
that.goodsLoading = false; that.goodsLoading = false;
@ -1079,11 +1176,6 @@
} }
}) })
}, },
// navbar
scrollHome: function(e) {
// uni.$emit('scroll');
// this.navShow = e.detail.scrollTop >= 50;
},
goback: function() { goback: function() {
uni.navigateBack(); uni.navigateBack();
@ -1095,16 +1187,6 @@
}); });
}, },
//
tab: function(param) {
console.log(param)
if (param == 9) return uni.switchTab({
url: "/pages/order_addcart/order_addcart"
})
this.tabActive = param;
this.goodsLoading = this.loadend = this.loading = false
},
resetParmas() { resetParmas() {
this.navActive = 0; this.navActive = 0;
this.where = { this.where = {
@ -1112,7 +1194,8 @@
keyword: '', keyword: '',
page: 1, page: 1,
limit: 30, limit: 30,
sale_type: this.where.sale_type sale_type: this.where.sale_type,
cate_pid: ''
} }
}, },
@ -1163,6 +1246,7 @@
} }
}, },
onPageScroll() { onPageScroll() {
this.isChangeSecTabStyle = false;
uni.$emit('scroll'); uni.$emit('scroll');
}, },
onPullDownRefresh() { onPullDownRefresh() {
@ -1177,6 +1261,56 @@
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.small-classify {
position: fixed;
left: 152rpx;
min-height: 94rpx;
background: #fff;
z-index: 100;
padding: 20rpx 20rpx 10rpx;
box-sizing: border-box;
.second-item-con-wrap {
position: relative;
display: flex;
align-items: center;
.second-item-con {
display: flex;
width: 95%;
overflow: auto;
}
.sanjiaoxing {
position: absolute;
right: -2rpx;
top: 20rpx;
width: 0;
height: 0;
border: 12rpx solid;
border-color: #333 transparent transparent transparent;
margin-left: 4rpx;
}
}
.small-classify-item {
flex-shrink: 0;
padding: 10rpx 40rpx;
border-radius: 4rpx;
font-size: 24rpx;
color: #999;
background: #F6F6F6;
text-align: center;
margin-right: 10rpx;
margin-bottom: 10rpx;
}
.small-classify-item-active {
background: #ECFFE8;
color: #40AE36;
}
}
.tab-cont { .tab-cont {
background: #f5f5f5; background: #f5f5f5;
min-height: 500rpx; min-height: 500rpx;
@ -2225,7 +2359,7 @@
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
align-items: center; align-items: center;
margin-top: 0; margin: 0 auto;
image { image {
width: 414rpx; width: 414rpx;

View File

@ -558,7 +558,8 @@
deduction_rate: '', // deduction_rate: '', //
order: '', // sales, price_asc, price_desc order: '', // sales, price_asc, price_desc
rand: 1, rand: 1,
} },
isIndexClick: true
} }
}, },
computed: { computed: {
@ -573,10 +574,19 @@
}, },
onTabItemTap(e) { onTabItemTap(e) {
uni.pageScrollTo({ if (this.isIndexClick) {
scrollTop: 0, uni.pageScrollTo({
duration: 300 scrollTop: 0,
}); duration: 300
});
} else {
this.isIndexClick = true;
}
},
onShow() {
console.log(this.isIndexClick)
this.isIndexClick = false;
}, },
onPageScroll(e) { onPageScroll(e) {