glhcp/uniapp/components/goods-column/goods-column.vue

144 lines
3.8 KiB
Vue

<template>
<!-- 当mescroll-body写在子组件时,父页面需引入mescroll-comp.js的mixins -->
<mescroll-body ref="mescrollRef" @init="mescrollInit" @down="downCallback" @up="upCallback"
:up="upOption" :down="downOption" v-if="hasData">
<!-- 数据列表 -->
<view class="goods-column">
<scroll-view scroll-x="true">
<view class="column-wrap">
<view class="item flex-col m-r-50 muted" v-for="(item, index) in columnList" :key="index" @tap="changeActive(index)">
<view class="xxl normal title" :class="{bold: active == index}">{{item.name}}</view>
<view class="m-t-8 xs text-center" :class="{normal : active == index}">{{item.remark}}</view>
<view v-if="active == index" class="line br60"></view>
</view>
</view>
</scroll-view>
</view>
<view class="goods">
<u-waterfall ref="uWaterfall" v-model="goodsList" :add-time="20">
<template v-slot:left="{leftList}">
<view style="padding:0 9rpx 0 30rpx">
<goods-list width="336rpx" type="waterfall" :list="leftList"></goods-list>
</view>
</template>
<template v-slot:right="{rightList}">
<view style="padding:0 30rpx 0 9rpx;">
<goods-list width="336rpx" type="waterfall" :list="rightList"></goods-list>
</view>
</template>
</u-waterfall>
</view>
</mescroll-body>
</template>
<script>
import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";
import {
getGoodsListColumn,
getGoodsColumn
} from "@/api/store"
export default {
mixins: [MescrollMixin], // 使用mixin
props:{
autoGetData: {
type: Boolean,
default:true
}
},
data() {
return {
goodsList: [],
active: 0,
columnList: [],
upOption: {
auto: false,
empty: {
icon: '/static/images/goods_null.png',
tip: "暂无商品",
}
},
downOption:{use: false, isLock: true},
hasData: true
}
},
mounted() {
if(this.autoGetData) {
this.getData()
}
},
methods: {
async getData() {
await this.getGoodsColumnFun()
this.$refs.uWaterfall && this.$refs.uWaterfall.clear();
this.mescroll.resetUpScroll();
},
changeActive(index) {
this.active = index
this.$refs.uWaterfall.clear();
this.mescroll.resetUpScroll();
},
/*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
upCallback(page) {
//联网加载数据
const {columnList, active} = this
const pageNum = page.num; // 页码, 默认从1开始
const pageSize = page.size; // 页长, 默认每页10条
if(!columnList.length) return
const columnId = columnList[active].id
getGoodsListColumn({
page_size: pageSize,
page_no: pageNum,
column_id: columnId
}).then(({
data
}) => {
let curPageData = data.lists;
let curPageLen = curPageData.length;
let hasNext = !!data.more;
if (page.num == 1) this.goodsList = [];
this.goodsList = this.goodsList.concat(curPageData);
this.mescroll.endSuccess(curPageLen, hasNext);
})
},
async getGoodsColumnFun() {
const {
data,
code
} = await getGoodsColumn()
if (code == 1) {
this.columnList = data
this.hasData = data.length ? true : false
}
}
}
}
</script>
<style lang="scss" scoped>
.goods-column {
.column-wrap {
display: inline-block;
white-space: nowrap;
padding: 30rpx;
.item {
display: inline-block;
position: relative;
overflow: hidden;
.title {
position: relative;
z-index: 1;
}
.line {
position: absolute;
top: 32rpx;
left: 0;
width: 144rpx;
height: 12rpx;
background: linear-gradient(90deg, #FF2C3C 0%, rgba(255, 44, 60, 0) 100%);
}
}
}
}
</style>