<template> <view class="containers" :style="viewColor"> <view class="header"> <view class="search"> <text class="iconfont icon-xiazai5"></text> <input type="text" placeholder="请输入商品名称" v-model="searchVal" @input="setValue" confirm-type="search" @confirm="searchBut()" placeholder-class='placeholder'> </view> <view class="iconclose" @click="close"> <image src="@/static/images/wt_close.png" mode="aspectFit"></image> </view> </view> <view class="main"> <scroll-view scroll-y="true" @touchmove.stop> <block> <view v-if="bought.length" @touchmove="onTouchmove" id="goods" class="goods"> <view class="picTxt acea-row" v-for="(item, i) in bought" :key="i"> <view class="checkbox"> <text @click.stop="goodsCheck(item)" v-if="item.check" class="iconfont icon-xuanzhong1"></text> <text @click.stop="goodsCheck(item)" v-else :class="checkedArr.length >=5 ? 'disabled': ''" class="iconfont icon-weixuanzhong"></text> </view> <view class='pictrue'> <image :src='item.image'></image> </view> <view class='text'> <view class='line2 name'>{{item.store_name}}</view> <view class="picTxt_one" v-if="item.attrValue.length>0"> <picker class="slecte" v-if="item.attrValue.length>1" @change="bindPickerChange($event,item.attrValue,i)" :value="index" :range="item.attrValue" :range-key="'sku'"> <view class="uni-input">{{item.attrValue[index].sku}}</view> </picker> <view class="" style="margin-top: 10rpx;"> 库存:{{item.attrValue[index].stock}} </view> </view> </view> <view class="picTxt_price"> <view class="price"> <span>出售价格</span> <input type="text" :value="item.price" placeholder="输入出售价格" @input="producrprice($event,i,item)" adjust-position="" placeholder-style="color: #CCCCCC;" /> </view> <view class="price_num"> <span>出售数量</span> <subtractive v-if='item.number==0' style="margin-top: 10rpx;margin-left: 20rpx;" class="step" :min="0" :max="item.attrValue[index].stock" :value="peicenumber" :isMax="true" :isMin="true" index="11" @eventChange="numberChange($event,i)"> </subtractive> <subtractive v-else style="margin-top: 10rpx;margin-left: 20rpx;" class="step" :min="0" :max="item.attrValue[index].stock" :value="item.number" :isMax="true" :isMin="true" index="11" @increment="incrementTotal($event,i,item)" @eventChange="numberChange($event,i)"></subtractive> </view> </view> </view> </view> <view v-else class="empty"> <image src="/static/images/no_thing.png"></image> <text>暂无内容哦~</text> </view> </block> </scroll-view> <view class="foot_bar"> <button class="confirm_btn" @click="submit">确定({{checkedArr.length}})</button> </view> </view> </view> </template> <script> import Loading from '@/components/Loading/index.vue'; import subtractive from '@/components/subtractive/subtractive.vue'; import { getCommunitygetOrderList } from "@/api/trading-floor"; import { mapGetters } from "vuex"; export default { props: { checkedObj: { type: Array, default: [] } }, computed: mapGetters(['viewColor']), components: { Loading, subtractive }, data() { return { isActive: 0, loadedb: false, loadingb: false, loadedc: false, loadingc: false, loadeds: false, loadings: false, whereb: { page: 1, limit: 10, keyword: '', }, peicenumber: 0, searchVal: "", checked: [], list: [], bought: [], checkedArr: [], aryys: [], // picker下拉数据源 storageCustomList: [{ CustGoodsCode: "TEST001", CustGoodsName: "测试货主001", IfBoxId: 0, IfProductId: 0, }, { CustGoodsCode: "TEST002", CustGoodsName: "测试货主002", IfBoxId: 0, IfProductId: 0, }, { CustGoodsCode: "TEST003", CustGoodsName: "测试货主003", IfBoxId: 0, IfProductId: 0, }], index: 0, pickerData: '请选择', itstock: '', }; }, watch: { checkedObj: { handler(n) { this.checkedArr = JSON.parse(JSON.stringify(n||{})) }, deep: true } }, mounted() { this.checkedArr = JSON.parse(JSON.stringify(this.checkedObj||{})) this.aryys = JSON.parse(JSON.stringify(this.checkedObj||{})) this.getBounht(); }, methods: { //价格 producrprice(e, i, item) { this.bought[i].price = e.detail.value // 处理数据回显时, 调整数量, 选中的数据不改变的问题 let obj = this.checkedArr.find((item)=>item.product_id==this.bought[i].product_id); obj ? obj.price = e.detail.value:null; // this.$set(item, 'check', false); // for (let i in this.checkedArr) { // if (this.checkedArr[i].product_id == item.product_id) { // this.checkedArr.splice(i, 1) // } // } }, incrementTotal(e, i, item) { // console.log(e, i, item) // this.$set(item, 'check', false); // for (let i in this.checkedArr) { // if (this.checkedArr[i].product_id == item.product_id) { // this.checkedArr.splice(i, 1) // } // } }, // picker修改事件 bindPickerChange: function(e, storage, num) { this.bought[num].attrValue[this.index].sku = storage[e.detail.value].sku this.bought[num].attrValue[this.index].stock = storage[e.detail.value].stock this.bought[num].product_attr_unique = storage[e.detail.value].unique this.pickerData = storage[this.index] // 这里就是选中的对象 if (this.bought[num].attrValue[this.index].stock == 0) { this.$util.Tips({ title: '库存不足' }); } }, // 点击关闭按钮 close() { this.$emit('close'); }, numberChange(data, i) { this.peicenumber = data.number; this.bought[i].number = data.number // 处理数据回显时, 调整数量, 选中的数据不改变的问题 let obj = this.checkedArr.find((item)=>item.product_id==this.bought[i].product_id); obj ? obj.number = data.number:null; }, tabs(index) { this.isActive = index this.$set(this.whereb, 'keyword', ''); this.searchVal = '' this.searchBut() }, onTouchmove(e) { if (this.loadendb) return; if (this.loadingb) return; const query = uni.createSelectorQuery().in(this); query.select('#goods').boundingClientRect(data => { if (data.bottom < 1500 && data.top < 0) { this.getBounht(); } }).exec(); // 模拟触底刷新 }, setValue: function(event) { this.$set(this.whereb, 'keyword', event.detail.value); if (!event.detail.value) { this.whereb.page = 1 this.loadedb = false this.getBounht() } }, searchBut() { this.bought = [] this.whereb.page = 1 this.loadedb = false this.getBounht() }, getBounht() { var that = this; // console.log('1111111', that.loadingb, that.loadedb) if (that.loadingb || that.loadedb) return; that.loadingb = true; getCommunitygetOrderList(that.whereb).then( res => { that.loadingb = false; that.loadedb = res.data.list.length < that.whereb.limit; that.bought.push.apply(that.bought, res.data.list); that.whereb.page = that.whereb.page + 1; that.getInitchecked(that.bought); }, error => { that.$util.Tips({ title: error.msg }) } ); }, /*获取初始化选中的数据*/ getInitchecked(arr) { let that = this; arr.forEach((item, index) => { that.$set(item, 'check', false); that.checkedArr.forEach((val, i) => { if (item.product_id == val.product_id) { that.$set(item, 'check', true); that.$set(item, 'number', val.number); that.$set(item, 'price', val.price); that.peicenumber=val.number } }) }) }, /*已选中的商品打钩*/ getCheckedGoods() { this.checked = [] this.checkedArr.forEach((item, index) => { this.checkedArr.push(item) }) }, /*点击选中与否*/ goodsCheck(item) { this.$set(item, 'check', !item.check); if (item.check) { if (this.peicenumber == 0) { item.number = 1 } if (!item.product_attr_unique) { item.product_attr_unique = item.attrValue[0].unique } this.checkedArr.push(item) } else { this.checkedArr.splice(this.checkedArr.findIndex(itemn => ((itemn.product_id == item.product_id))), 1) } }, /*确定提交*/ submit() { this.$emit('getProduct', this.checkedArr); }, } } </script> <style lang="scss" scoped> .containers { background: #ffffff; border-radius: 16rpx 16rpx 0 0; padding: 40rpx 0; position: relative; .header { position: relative; padding: 0 30rpx; .title { width: 100%; text-align: center; text { position: relative; margin: 0 50rpx; color: #999999; font-size: 30rpx; &.on { color: #333333; font-weight: bold; font-size: 34rpx; &::after { content: ""; display: inline-block; width: 40rpx; height: 5rpx; background: var(--view-theme); position: absolute; bottom: -10rpx; left: 10rpx; } } } } .iconclose { width: 44rpx; height: 44rpx; line-height: 44rpx; border-radius: 50%; text-align: center; position: absolute; top: -150rpx; right: 30rpx; image { width: 100%; height: 100%; } } .search { margin-top: 44rpx; background: #F5F5F5; border-radius: 30rpx; padding: 12rpx 30rpx 12rpx 66rpx; position: relative; .iconfont { font-size: 24rpx; color: #939393; position: absolute; top: 20rpx; left: 30rpx; } .placeholder { color: #999999; font-size: 26rpx; } } .sub_title { color: #282828; font-size: 26rpx; margin-top: 30rpx; } .iconfont { color: #8A8A8A; font-size: 28rpx; position: absolute; top: 0; right: 30rpx; } } scroll-view { height: 650rpx; } .main { height: 650rpx; margin: 40rpx 0 80rpx; padding: 0 30rpx; } } .picTxt { width: 100%; padding: 25rpx 0; position: relative; align-items: center; justify-content: space-between; border-top: 2rpx solid #E7E6E4; .picTxt_one { white-space: nowrap; overflow: hidden; } .picTxt_one { display: flex; margin-top: 20rpx; .slecte { margin-right: 30rpx; width: 280rpx; height: 60rpx; line-height: 60rpx; text-align: center; font-size: 28rpx; font-family: PingFang SC-Regular, PingFang SC; font-weight: 400; color: #959595; background-color: #E7E6E4; border-radius: 10rpx 10rpx 10rpx 10rpx; white-space: nowrap; overflow: hidden; } } .picTxt_price { display: flex; margin-top: 37rpx; height: 70rpx; line-height: 70rpx; .price { display: flex; margin-right: 15rpx; input { width: 210rpx; text-align: center; height: 70rpx; background: #F5F5F5; border-radius: 7rpx 7rpx 7rpx 7rpx; font-size: 28rpx; font-family: PingFang SC-Regular, PingFang SC; font-weight: 400; margin-left: 20rpx; } } .price_num { display: flex; } } .checkbox { margin-right: 30rpx; .iconfont { font-size: 38rpx; color: #CCCCCC; } .icon-xuanzhong1 { color: var(--view-theme); } .disabled { pointer-events: none; cursor: default; opacity: 0.3; } } .pictrue { width: 160rpx; height: 160rpx; image { width: 100%; height: 100%; border-radius: 8rpx; } } .text { width: 430rpx; margin-left: 30rpx; font-size: 28rpx; color: #282828; position: relative; height: 160rpx; .name { color: #282828; font-size: 28rpx; } .money { position: absolute; bottom: 0; left: 0; color: var(--view-priceColor); font-size: 22rpx; font-weight: bold; text { font-size: 26rpx; } } } } .foot_bar { width: 100%; position: fixed; // bottom: 54px; left: 0; padding: 20rpx 0; z-index: 5; .confirm_btn { width: 710rpx; height: 86rpx; line-height: 86rpx; color: #ffffff; text-align: center; font-size: 32rpx; background: var(--view-theme); border-radius: 43rpx; margin: 0 auto; } } .empty { margin: 130rpx 0 150rpx; text-align: center; image, uni-image { display: inline-block; width: 414rpx; height: 305rpx; } text { display: block; color: #999999; font-size: 26rpx; } } </style>