企业🤖AI Agent构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
### 商品规格的实现 > 规格页面主要封装为组件的形式,将得到的数据传入到子组件当中,很多时候也得根据后端的数据来 > 子组件需要接收的 ``` props: { goodsAttr: { type: Array, default: () => [], }, goods: { default: function() { return {} } }, item: { default: function() { return {} } }, }, ``` > watch监听 ``` watch: { goods: { handler(newValue, oldValue) { this.goodsStockNumber = this.goods.store_nums; this.goodsPrice = this.goods.sell_price; let fields = {}; for (let i in this.goods) { if (this.$utils.in_array(i, this.fields)) { fields[i] = this.goods[i]; } } Object.assign(fields, { id: this.goods.id, num: this.number, isSubmit: true, selectedSku: { id: "", specSelected: "" } }); this.selectedGoodsInfo = fields; }, deep: true }, /** * 对于规格的处理 */ goodsAttr: { handler(newValue, oldValue) { // console.log(2, 'goodsAttr'); if (this.goodsAttr.length <= 0) { return; } let arr = []; this.selectedSku = []; for (let obj in this.goodsAttr) { for (let index in this.goodsAttr[obj]['list']) { if (this.goodsAttr[obj]['list'][index]['selected'] && !this.goodsAttr[obj]['list'][index][ 'disable' ]) { this.selectedSku.push(this.goodsAttr[obj]['list'][index]); arr.push({ name: this.goodsAttr[obj].name, value: this.goodsAttr[obj]['list'][index].value }); } } } let selectedIndex = []; for (let obj in this.selectedSku) { selectedIndex.push(this.selectedSku[obj].pid + "_" + this.selectedSku[obj].id); } if (this.goodsAttr.length == selectedIndex.length && this.item[selectedIndex.join("_")] != undefined) { let g = this.item[selectedIndex.join("_")]; this.goodsPrice = g.sell_price; this.goodsStockNumber = g.store_nums; if (this.number >= g.store_nums) { this.number = g.store_nums; } this.selectedGoodsInfo.selectedSku.id = g.product_id; this.selectedGoodsInfo.isSubmit = true; } else { this.selectedGoodsInfo.isSubmit = false; } this.specSelected = ''; let s = []; for (let i in arr) { s.push(arr[i].name + ":" + arr[i].value); } if (s.length > 0) { this.selectedGoodsInfo.selectedSku.specSelected = s.join(","); this.specSelected = "己选择:" + s.join(","); } // console.log(5, this.selectedGoodsInfo); }, deep: true }, }, ``` > 规格点击 ``` /** * 属性选择点击 */ onAttrSize(id, value, index, idx, pid) { let specArray = []; for (let i in this.goodsAttr) { specArray[i] = "[A-Za-z0-9_\\:\\,]+"; if (id == this.goodsAttr[i]['id']) { for (let j in this.goodsAttr[i]['list']) { let value = this.goodsAttr[i]['list'][j]; if (id == value['pid'] && pid == value['id']) { let flag = !value.selected; this.$set(this.goodsAttr[i]['list'][j], 'selected', flag); if (flag == true) { specArray[i] = value.pid + ":" + value.id; } } else { this.$set(this.goodsAttr[i]['list'][j], 'selected', false); } } } } for (let i in this.goodsAttr) { for (let j in this.goodsAttr[i]['list']) { let value = this.goodsAttr[i]['list'][j]; let temp = specArray.slice(); temp[i] = value.pid + ":" + value.id; let flag = true; for (let j in this.item) { let reg = new RegExp(temp.join(",")); if (reg.test(this.item[j].key) && this.item[j].store_nums > 0) { flag = false; } } this.$set(this.goodsAttr[i]['list'][j], 'disable', flag); } } }, ``` > 样式实现 ``` <view class="size-list"> <div class="list" v-for="(value, idx) in item.list" :class="{'action': value.selected && value.disable == false}" @click.stop="onAttrSize(item.id,value,index,idx,value.id)" :key="idx"> <text>{{value.value}}</text> </div> </view> ``` #### 实现思想 正在构思中