首页 / VUE / 基于Vue实现电商SKU组合算法问题
基于Vue实现电商SKU组合算法问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了基于Vue实现电商SKU组合算法问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2318字,纯文字阅读大概需要4分钟。
内容图文
前段时间,公司要做“添加商品”业务模块,这也算是电商业务里面的一个难点了。
令我印象最深的不是什么“组合商品”、“关联商品”、“关联单品”,而是商品SKU的组合问题。
这个问题特别有意思,当时虽然大体上组合成功,总是有些小bug解决不了,然后手上又有别的任务就没仔细研究它。
后来过了一个月,空闲下来专门研究了下,终于把问题解决,有必要记录下这次体验。
先看下在业务中的效果(tips: 如看不清可放大浏览器)
这个相对来说比较麻烦,还涉及到了下面“属性图片”的循环,但关键点还是在SKU组合的代码上面
以下是基于element-ui和vue的精简版demo代码:
html:
<div>SKU组合demo</div> <div v-for="(v, i) in list" :key="i" class="mt-20"> <b>{{ v.name }}:</b> <el-checkbox-group v-model="checkList[i].list"> <el-checkbox v-for="(k, j) in v.list" :key="j" :label="k" /> </el-checkbox-group> </div> <div class="mt-20"> <el-button type="primary" @click="handleClick">确定</el-button> </div> <div class="mt-20"> <el-tag v-for="(item, index) in skuList" :key="index" style="margin:10px 10px;">{{ item }}</el-tag> </div>
css:
.mt-20 { margin-top: 20px; }
JS:
<script> export default { data() { return { list: [ { name: '尺码', list: ['S', 'M', 'L', 'XL', 'XXL'] }, { name: '颜色', list: ['红色', '黄色', '蓝色', '粉色', '紫色'] }, { name: '图案', list: ['猫咪', '人物', '飞机', '闪电', '字母'] } ], checkList: [ { name: '尺码', list: [] }, { name: '颜色', list: [] }, { name: '图案', list: [] } ], skuArray: [], skuList: [] } }, methods: { handleClick() { // 先清空数据,保证连续点击按钮,数据不会重复 this.skuArray = [] this.skuList = [] // 将选中的规格组合成一个大数组 [[1, 2], [a, b]...] this.checkList.forEach(element => { element.list.length > 0 ? this.skuArray.push(element.list) : '' }) // 勾选了规格,才调用方法 if (this.skuArray.length > 0) { this.getSkuData([], 0, this.skuArray) } else { this.$message.error('请先勾选规格') } }, // 递归获取每条SKU数据 getSkuData(skuArr = [], i, list) { for (let j = 0; j < list[i].length; j++) { if (i < list.length - 1) { skuArr[i] = list[i][j] this.getSkuData(skuArr, i + 1, list) // 递归循环 } else { this.skuList.push([...skuArr, list[i][j]]) // 扩展运算符,连接两个数组 } } } } } </script>
效果如下:
只要是做电商的小伙伴应该都会遇到这个SKU组合问题吧,希望能对大家有所帮助!
总结
以上所述是小编给大家介绍的基于Vue实现电商SKU组合算法问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
内容总结
以上是互联网集市为您收集整理的基于Vue实现电商SKU组合算法问题全部内容,希望文章能够帮你解决基于Vue实现电商SKU组合算法问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。