Files
2026-03-08 20:07:52 +08:00

498 lines
12 KiB
Vue
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<template>
<view :data-theme="theme">
<tui-skeleton v-if="showSkeleton"></tui-skeleton>
<view class='productSort' :style="{visibility: showSkeleton ? 'hidden' : 'visible', height: winHeight+ 'px' }">
<!-- #ifdef APP -->
<view class="w-100-p111-" :style="{ 'height' : `${searchTop}`}"></view>
<!-- #endif -->
<searchBox :toBackShow="false" @searchChange="searchSubmitValue"></searchBox>
<view class="con-box">
<view class='aside'>
<scroll-view scroll-y="true" style="height: 100%; overflow: hidden;" scroll-with-animation='true'
:scroll-into-view="intoindex">
<view v-for="(item,index) in productList" :key="item.id">
<view class='item acea-row row-center-wrapper' :class='index==navActive?"on":""'
v-if='item.childList && item.childList.length > 0' :key="item.id"
@click='tap(index,"b"+item.id)' :id='"sort"+index'><text
class="item_text skeleton-rect">{{item.name}}</text>
</view>
</view>
</scroll-view>
</view>
<view class='conter'>
<scroll-view scroll-y="true" :scroll-into-view="toView" style="height: 100%; overflow: hidden;"
@scroll="scroll" scroll-with-animation='true'>
<view v-for="(p,i) in productList" :key="p.id">
<view class='listw' :id="'b'+p.id+index" v-for="(item,index) in p.childList" :key="item.id">
<view class='title acea-row'>
<view class='name skeleton-rect'>{{item.name}}</view>
</view>
<view class='list acea-row borRadius14'>
<block v-for="(itemn,indexn) in item.childList" :key="itemn.id">
<navigator hover-class='none'
:url='"/pages/goods/goods_list/index?cid="+itemn.id+"&title="+itemn.name'
class='item acea-row row-column row-middle'>
<view class='picture skeleton-rect'>
<easy-loadimage mode="widthFix"
:image-src="itemn.icon"></easy-loadimage>
</view>
<view class='name line1'>{{itemn.name}}</view>
</navigator>
</block>
</view>
</view>
</view>
<view :style='"height:"+(bottomheight-300)+"rpx;"'></view>
</scroll-view>
</view>
</view>
</view>
<view v-if="bottomNavigationIsCustom" class="footerBottom"></view>
<page-footer></page-footer>
</view>
</template>
<script>
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2026 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
let app = getApp();
import {
getCategoryList
} from '@/api/product.js';
import easyLoadimage from '@/components/base/easy-loadimage.vue';
import {
mapGetters
} from "vuex";
import tuiSkeleton from '@/components/base/tui-skeleton.vue';
import pageFooter from "@/components/pageFooter/index.vue";
import animationType from '@/utils/animationType.js'
import searchBox from "@/components/searchBox.vue";
let sysHeight = uni.getSystemInfoSync().statusBarHeight;
export default {
components: {
easyLoadimage,
tuiSkeleton,
pageFooter,
searchBox
},
computed: mapGetters(['bottomNavigationIsCustom']),
data() {
let active = 0;
// #ifdef H5
active = location.hash.substr(1);
// #endif
return {
theme: app.globalData.theme,
showSkeleton: true, //骨架屏显示隐藏
navlist: [],
hotList: [], //推荐分类
sysHeight: sysHeight,
searchTop: 0,
productList: [{
name: 'skeleton',
id: 0,
childList: [{
name: 'skeleton',
id: 10,
childList: [{
name: '',
id: 101,
},
{
name: '',
id: 102,
},
{
name: '',
id: 103,
},
{
name: '',
id: 104,
},
{
name: '',
id: 105,
},
{
name: '',
id: 106,
}
]
},
{
name: 'skeleton',
id: 1,
childList: [{
name: '',
id: 101,
},
{
name: '',
id: 102,
},
{
name: '',
id: 103,
},
{
name: '',
id: 104,
},
{
name: '',
id: 105,
},
{
name: '',
id: 106,
}
]
},
{
name: '',
id: 20
}
]
},
{
name: 'skeleton',
id: 2,
childList: [{
name: 'skeleton',
id: 30
}]
},
{
name: 'skeleton',
id: 3,
childList: [{
name: 'skeleton',
id: 31
}]
},
{
name: 'skeleton',
id: 4,
childList: [{
name: 'skeleton',
id: 32
}]
},
{
name: 'skeleton',
id: 5,
childList: [{
name: 'skeleton',
id: 33
}]
},
{
name: 'skeleton',
id: 6,
childList: [{
name: 'skeleton',
id: 34
}]
},
{
name: 'skeleton',
id: 7,
childList: [{
name: 'skeleton',
id: 35
}]
},
{
name: 'skeleton',
id: 8,
childList: [{
name: 'skeleton',
id: 36
}]
},
{
name: 'skeleton',
id: 9,
children: [{
name: 'skeleton',
id: 37
}]
},
{
name: 'skeleton',
id: 10,
childList: [{
name: 'skeleton',
id: 38
}]
},
{
name: 'skeleton',
id: 11,
childList: [{
name: 'skeleton',
id: 39
}]
},
],
navActive: 0,
activceCate: active,
number: "",
bottomheight: 0,
hightArr: [],
toView: "",
winHeight: 0,
pidIndex: 0,
intoindex: "",
pid: '',
newData: {},
activeRouter: '',
}
},
onLoad(options) {
let that = this
// #ifdef APP
this.searchTop = `${this.sysHeight*2}rpx`
// #endif
uni.getSystemInfo({
success: function(res) {
that.winHeight = res.windowHeight
},
});
// #ifdef H5
document.body.addEventListener('touchmove', function(event) {
if (that.$route.path == '/pages/goods_cate/goods_cate') {
event.preventDefault();
}
}, {
passive: false
});
// #endif
this.getAllCategory();
},
onShow() {
let that = this
let routes = getCurrentPages();
let curRoute = routes[routes.length - 1].route;
this.activeRouter = '/' + curRoute;
if (uni.getStorageSync('cateNavActive')) {
this.navActive = uni.getStorageSync('cateNavActive') - 1;
uni.removeStorageSync('cateNavActive');
}
if (uni.getStorageSync('categoryId')) {
this.pid = uni.getStorageSync('categoryId');
uni.removeStorageSync('categoryId');
}
this.pid && this.navActive && setTimeout(() => this.tap(this.navActive, 'b' + this.pid), 200);
setTimeout(() => {
uni.removeStorageSync('categoryId');
uni.removeStorageSync('cateNavActive');
}, 300);
},
methods: {
infoScroll: function() {
let that = this;
//设置商品列表高度
uni.getSystemInfo({
success: function(res) {
that.bottomheight = (res.windowHeight) * (750 / res.windowWidth) - 98;
},
});
let hightArr = [];
for (let i = 0; i < that.productList.length; i++) {
let item = that.productList[i]
if (!that.productList[i].childList) {
continue;
}
for (let j = 0; j < that.productList[i].childList.length; j++) {
//获取元素所在位置
let query = uni.createSelectorQuery().in(this);
let idView = "#b" + item.id + j;
query.select(idView).boundingClientRect();
query.exec(function(res) {
if (res[0]) {
let top = res[0].top;
hightArr.push({
top,
i
});
}
});
};
};
that.hightArr = hightArr;
},
tap: function(index, id) {
this.toView = '' + id + 0;
this.navActive = index;
setTimeout(() => {
uni.$emit('scroll');
}, 300);
},
getAllCategory: function() {
let that = this;
let value = ""
that.pidIndex = 0;
getCategoryList().then(res => {
that.productList = res.data;
that.$nextTick(function() {
that.infoScroll();
})
that.showSkeleton = false
})
},
scroll: function(e) {
uni.$emit('scroll');
let scrollTop = e.detail.scrollTop + 10;
let scrollArr = this.hightArr;
for (let i = 0; i < scrollArr.length; i++) {
if (scrollTop >= 0 && scrollTop < scrollArr[1].top - scrollArr[0].top) {
this.navActive = 0
} else if (scrollTop >= scrollArr[i].top - scrollArr[0].top && scrollTop < (scrollArr[i + 1] ?
scrollArr[i + 1].top : 0) - scrollArr[0].top) {
this.navActive = scrollArr[i].i
} else if (scrollTop >= scrollArr[scrollArr.length - 1].top - scrollArr[0].top) {
this.navActive = scrollArr[scrollArr.length - 1].i
}
}
},
searchSubmitValue: function(e) {
if (this.$util.trim(e.detail.value).length > 0)
uni.navigateTo({
animationType: animationType.type,
animationDuration: animationType.duration,
url: '/pages/goods/goods_list/index?searchValue=' + e.detail.value
})
else
return this.$util.Tips({
title: '请填写要搜索的产品信息'
});
},
}
}
</script>
<style scoped lang="scss">
/deep/.origin-img {
border-radius: 50%;
}
.productSort {
display: flex;
flex-direction: column;
width: 100%;
.con-box {
flex: 1;
display: flex;
overflow: hidden;
}
}
.productSort .aside {
background-color: #fff;
overflow-y: auto;
overflow-x: hidden;
width: 200rpx;
height: 100%;
overflow: hidden;
}
.productSort .aside .item {
height: 100rpx;
width: 100%;
font-size: 26rpx;
color: #282828;
}
.productSort .aside .item_text {
padding-left: 20rpx;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
.productSort .aside .item.on {
background-color: #f7f7f7;
@include border_left(theme);
width: 100%;
text-align: center;
@include main_color(theme);
font-weight: bold;
}
.productSort .conter {
flex: 1;
height: 100%;
padding: 0 20rpx;
background-color: #f7f7f7;
}
.productSort .conter .listw .title {
height: 100rpx;
align-items: center;
}
.productSort .conter .listw .title .line {
width: 100rpx;
height: 2rpx;
background-color: #f0f0f0;
}
.productSort .conter .listw .title .name {
font-size: 26rpx;
color: #282828;
margin: 0 30rpx;
font-weight: bold;
}
.productSort .conter .listw .title .list_title,
.productSort .conter .listw .title uni-image,
.productSort .conter .listw .title image {
width: 110rpx;
height: 26rpx;
border-radius: 0;
}
.productSort .conter .list {
flex-wrap: wrap;
background: #fff;
padding-bottom: 26rpx;
}
.productSort .conter .list .item {
width: 170rpx;
margin-top: 26rpx;
}
.productSort .conter .list .item .picture,
.productSort .conter uni-image,
.productSort .conter .list .item image,
/deep/.easy-loadimage {
width: 110rpx;
height: 110rpx;
border-radius: 50%;
}
.productSort .conter .list .item .name {
font-size: 24rpx;
color: #333;
height: 56rpx;
line-height: 56rpx;
width: 120rpx;
text-align: center;
}
.searchBox {
width: 100%;
}
</style>