vue前端sku实现
this.value.skuStockList = [];let skuList = this.value.skuStockList;//只有一个属性时if (this.selectProductAttr.length === 1) {let attr = this.selectProductAttr[0];for (let i = 0; i < attr.values.length; i++) {skuList.push({spData: JSON.stringify([{key:attr.name,value:attr.values[i]}])});}} else if (this.selectProductAttr.length === 2) {let attr0 = this.selectProductAttr[0];let attr1 = this.selectProductAttr[1];for (let i = 0; i < attr0.values.length; i++) {if (attr1.values.length === 0) {skuList.push({spData: JSON.stringify([{key:attr0.name,value:attr0.values[i]}])});continue;}for (let j = 0; j < attr1.values.length; j++) {let spData = [];spData.push({key:attr0.name,value:attr0.values[i]});spData.push({key:attr1.name,value:attr1.values[j]});skuList.push({spData: JSON.stringify(spData)});}}} else {let attr0 = this.selectProductAttr[0];let attr1 = this.selectProductAttr[1];let attr2 = this.selectProductAttr[2];for (let i = 0; i < attr0.values.length; i++) {if (attr1.values.length === 0) {skuList.push({spData: JSON.stringify([{key:attr0.name,value:attr0.values[i]}])});continue;}for (let j = 0; j < attr1.values.length; j++) {if (attr2.values.length === 0) {let spData = [];spData.push({key:attr0.name,value:attr0.values[i]});spData.push({key:attr1.name,value:attr1.values[j]});skuList.push({spData: JSON.stringify(spData)});continue;}for (let k = 0; k < attr2.values.length; k++) {let spData = [];spData.push({key:attr0.name,value:attr0.values[i]});spData.push({key:attr1.name,value:attr1.values[j]});spData.push({key:attr2.name,value:attr2.values[k]});skuList.push({spData: JSON.stringify(spData)});}}}}
假设的选择属性数据
假设选择的商品属性如下(可以根据需要调整):
this.selectProductAttr = [{ name: "颜色", values: ["红色", "蓝色"] },{ name: "大小", values: ["S", "M"] },{ name: "材质", values: ["棉", "羊毛"] }
];
初始化部分
首先,代码初始化了一个空数组 skuStockList,并通过 skuList 引用指向该数组。
this.value.skuStockList = [];
let skuList = this.value.skuStockList;
这段代码的目的是为后续生成的 SKU 列表提供一个存储地方。
处理不同数量的属性
接下来,代码根据 this.selectProductAttr.length 的值判断当前有多少个属性被选择。根据属性的数量,代码将生成不同数量的组合 SKU。
1. 只有一个属性时
if (this.selectProductAttr.length === 1) {let attr = this.selectProductAttr[0]; // 获取第一个属性for (let i = 0; i < attr.values.length; i++) { // 遍历该属性的所有值skuList.push({spData: JSON.stringify([{ key: attr.name, value: attr.values[i] }])});}
}
执行过程:
- 只有一个属性
"颜色",其值为["红色", "蓝色"]。 - 对这个属性的每一个值,生成一个 SKU 并推入
skuList。
结果:
[{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"}]"}
]
2. 有两个属性时
else if (this.selectProductAttr.length === 2) {let attr0 = this.selectProductAttr[0]; // 获取第一个属性let attr1 = this.selectProductAttr[1]; // 获取第二个属性for (let i = 0; i < attr0.values.length; i++) { // 遍历第一个属性的所有值if (attr1.values.length === 0) { // 如果第二个属性没有值skuList.push({spData: JSON.stringify([{ key: attr0.name, value: attr0.values[i] }])});continue; // 跳过当前循环,继续处理下一个第一个属性的值}for (let j = 0; j < attr1.values.length; j++) { // 遍历第二个属性的所有值let spData = [];spData.push({ key: attr0.name, value: attr0.values[i] }); // 添加第一个属性的值spData.push({ key: attr1.name, value: attr1.values[j] }); // 添加第二个属性的值skuList.push({spData: JSON.stringify(spData)});}}
}
执行过程:
- 有两个属性
"颜色"和"大小",其中"颜色"有["红色", "蓝色"],"大小"有["S", "M"]。 - 代码会生成两个属性的所有组合。即,遍历
"颜色"的每一个值,并与"大小"的每个值进行配对。
结果:
[{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"S\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"M\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"S\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"M\"}]"}
]
3. 有三个属性时
else {let attr0 = this.selectProductAttr[0]; // 获取第一个属性let attr1 = this.selectProductAttr[1]; // 获取第二个属性let attr2 = this.selectProductAttr[2]; // 获取第三个属性for (let i = 0; i < attr0.values.length; i++) { // 遍历第一个属性的所有值if (attr1.values.length === 0) { // 如果第二个属性没有值skuList.push({spData: JSON.stringify([{ key: attr0.name, value: attr0.values[i] }])});continue; // 跳过当前循环,继续处理下一个第一个属性的值}for (let j = 0; j < attr1.values.length; j++) { // 遍历第二个属性的所有值if (attr2.values.length === 0) { // 如果第三个属性没有值let spData = [];spData.push({ key: attr0.name, value: attr0.values[i] }); // 添加第一个属性的值spData.push({ key: attr1.name, value: attr1.values[j] }); // 添加第二个属性的值skuList.push({spData: JSON.stringify(spData)});continue; // 跳过当前循环,继续处理下一个第二个属性的值}for (let k = 0; k < attr2.values.length; k++) { // 遍历第三个属性的所有值let spData = [];spData.push({ key: attr0.name, value: attr0.values[i] }); // 添加第一个属性的值spData.push({ key: attr1.name, value: attr1.values[j] }); // 添加第二个属性的值spData.push({ key: attr2.name, value: attr2.values[k] }); // 添加第三个属性的值skuList.push({spData: JSON.stringify(spData)});}}}
}
执行过程:
- 有三个属性
"颜色"、"大小"和"材质",其值分别为:"颜色":["红色", "蓝色"]"大小":["S", "M"]"材质":["棉", "羊毛"]
- 代码会生成三个属性的所有组合。即,遍历
"颜色"的每一个值,和"大小"、"材质"的每个值进行配对。
结果:
[{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"S\"},{\"key\":\"材质\",\"value\":\"棉\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"S\"},{\"key\":\"材质\",\"value\":\"羊毛\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"M\"},{\"key\":\"材质\",\"value\":\"棉\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"红色\"},{\"key\":\"大小\",\"value\":\"M\"},{\"key\":\"材质\",\"value\":\"羊毛\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"S\"},{\"key\":\"材质\",\"value\":\"棉\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"S\"},{\"key\":\"材质\",\"value\":\"羊毛\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"M\"},{\"key\":\"材质\",\"value\":\"棉\"}]"},{"spData": "[{\"key\":\"颜色\",\"value\":\"蓝色\"},{\"key\":\"大小\",\"value\":\"M\"},{\"key\":\"材质\",\"value\":\"羊毛\"}]"}
]
总结
- 代码根据选择的商品属性数量动态生成不同数量的 SKU 组合。
- 当属性数量为 1 时,生成一个包含该属性所有值的 SKU 列表。
- 当属性数量为 2 时,生成包含这两个属性所有值的组合 SKU 列表。
- 当属性数量为 3 时,生成包含三个属性的所有组合 SKU 列表。
- 每一个 SKU 都是一个包含属性名和值的 JSON 字符串,保存在
skuStockList中。
通过这些步骤,代码可以灵活地处理多属性商品的不同组合,最终生成不同的 SKU 列表。
相关文章:
vue前端sku实现
this.value.skuStockList [];let skuList this.value.skuStockList;//只有一个属性时if (this.selectProductAttr.length 1) {let attr this.selectProductAttr[0];for (let i 0; i < attr.values.length; i) {skuList.push({spData: JSON.stringify([{key:attr.name,v…...
使用Vue3和Vue2进行开发的区别
使用Vue3和Vue2进行开发的区别 笔者虽然老早就是用vue3进行开发了,但是上次有人问道使用vue3进行开发跟使用vue2进行开发的区别有哪些这个问题的时候,回答的还是有些琐碎,干脆今天专门整理一下,做个记录。 一、再也不用set了 众所…...
爬虫入门urllib 和 request(二)
文章目录 1、urllib介绍2、urllib的基本方法介绍2.1 urllib.Request2.2 response.read() 3、urllib请求百度首页的完整例子4、小结 1、urllib介绍 除了requests模块可以发送请求之外, urllib模块也可以实现请求的发送,只是操作方法略有不同! urllib在python中分为urllib和url…...
【大数据学习 | HBASE】hbase的整体架构
hbase的region存储原理图 首先我们看到hbase的组成分为两个大的部分,分别是hmaster和hregionserver,主节点用于协调数据,regionserver用于真正的去管理表,其中regionserver存在多个,他们共同协调管理全有的表ÿ…...
群控系统服务端开发模式-应用开发-个人资料
群控系统服务端开发模式后端基础框架现在就差个人资料、及权限验证。下面开发个人资料。 一、获取个人信息 1、添加路由 在根目录下route文件夹下面app.php文件中添加如下代码: Route::post(member/personal_data,permission.Member/personalData);// 获取个人信息…...
openssl生成加密,公钥实现非对称加密
私钥用于加密,公钥用于解密 私钥用于颁发token,公钥用于验证token,公钥不能颁发token 私钥和公钥是一对,不能单独使用,利用私钥生成公钥,利用公钥进行解密 使用openssl来生成一对私钥和公钥:ope…...
[CKS] K8S Admission Set Up
最近准备花一周的时间准备CKS考试,在准备考试中发现有一个题目关于Admission。 Whats Admission Kubernetes Admission是Kubernetes集群中一种机制,用于控制和修改集群中的资源对象。它允许您在Kubernetes资源被创建、更新或删除之前,对资源…...
前端学习Day13 CSS盒子的定位(固定定位篇“附练习”)
一、固定定位 固定定位 (position:fixed)其实是绝对定位的子类别,一个设置了 position:fixed 的元素是相对于视窗固定的,就算页面文档发生了滚动,它也会一直待在相同的地方。 ⚠️:固定定位会脱离文档流。…...
Tomcat 启动卡住,日志显示 At least one JAR was scanned for TLDs yet contained no TLDs.
现象 Tomcat 启动后,控制台输出卡在了: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JA…...
计算机网络:网络层 —— 移动 IP 技术
文章目录 IPv6IPv6 的诞生背景主要优势IPv6引进的主要变化 IPv6数据报的基本首部IPv6数据报首部与IPv4数据报首部的对比 IPv6数据报的拓展首部IPv6地址IPv6地址空间大小IPv6地址的表示方法 IPv6地址的分类从IPv4向IPv6过渡使用双协议栈使用隧道技术 网际控制报文协议 ICMPv6ICM…...
useCrudSchemas
摘要: useCrudSchemas 不是一个标准的JavaScript或数据库操作库函数,也不是一个广泛认知的术语。它可能是某个特定项目或应用程序中定义的一个自定义函数或方法,用于简化CRUD(创建、读取、更新、删除)操作。 在Web开发…...
SpringBoot3集成Junit5
目录 1. 确保项目中包含相关依赖2. 配置JUnit 53. 编写测试类4、Junit5 新增特性4.1 注解4.2 断言4.3 嵌套测试4.4 总结 在Spring Boot 3中集成JUnit 5的步骤相对简单。以下是你可以按照的步骤: 1. 确保项目中包含相关依赖 首先,确保你的pom.xml文件中…...
【EMNLP2024】阿里云人工智能平台 PAI 多篇论文入选 EMNLP2024
近期,阿里云人工智能平台 PAI 的多篇论文在 EMNLP2024 上入选。论文成果是阿里云与华南理工大学金连文教授团队、复旦大学王鹏教授团队共同研发。EMNLP 是人工智能自然语言处理领域的顶级国际会议,聚焦于自然语言处理技术在各个应用场景的学术研究&#…...
Spark的Shuffle过程
一、Shuffle 的作用是什么? Shuffle 操作可以理解为将集群中各个节点上的数据进行重新整理和分类的过程。这一概念源自 Hadoop 的 MapReduce 模型,Shuffle 是连接 Map 阶段和 Reduce 阶段的关键环节。在分布式计算中,每个计算节点通常只处理任…...
Java+Swing可视化图像处理软件
JavaSwing可视化图像处理软件 一、系统介绍二、功能展示1.图片裁剪2.图片缩放3.图片旋转4.图像灰度处理5.图像变形6.图像扭曲7.图像移动 三、系统实现1.ImageProcessing.java 四、其它1.其他系统实现2.获取源码 一、系统介绍 该系统实现了图片裁剪、缩放、旋转、图像灰度处理、…...
RDD转换算子:【mapValues、mapPartitions】
文章目录 1、mapValues算子功能语法举例 2、mapPartitions算子功能语法举例 1、mapValues算子 功能 针对二元组KV类型的RDD,对RDD中每个元素的Value进行map处理,结果放入一个新的RDD中 语法 def mapValues(self: RDD[Tuple[K,V]], f: (V) -> U) -…...
数组和指针的复杂关系
C语言中指针和数组的关系似乎很“纠结”,让人爱恨交织。本文试图帮助读者理清它们之间的复杂关系! 数组名的理解 数组元素在内存中是连续存放的,在C语言中,数组名有特殊的含义,它表示数组首元素的地址。因此…...
Linux系统I/O调优实例
文章目录 一 、资源限制二、测试硬盘速度: 一 、资源限制 限制用户资源配置文件:/etc/security/limits.conf [rootxuegod63 ~]# vim /etc/security/limits.conf 每行的格式: 用户名/用户组名 类型(软限制/硬限制) 选项 值 通常我们在服务器…...
记录Ubuntu OS的异常
PS: 参加过408改卷的ZJU ghsongzju.edu.cn 开启嘲讽: 你们知道408有多简单吗,操作系统真实水平自己知道就行~~ dmesg dmesg 是一个用于显示内核环形缓冲区消息的命令,主要用于查看系统启动时的消息、驱动程序加载信息、硬件错误…...
Vue 3 单元测试与E2E测试
在Vue 3应用的开发过程中,测试是一个至关重要的环节。它不仅能够确保代码的正确性,还能在后续的代码重构和升级过程中提供安全保障。本文将深入探讨Vue 3的单元测试(Unit Testing)和端到端测试(End-to-End Testing, E2…...
华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
MySQL账号权限管理指南:安全创建账户与精细授权技巧
在MySQL数据库管理中,合理创建用户账号并分配精确权限是保障数据安全的核心环节。直接使用root账号进行所有操作不仅危险且难以审计操作行为。今天我们来全面解析MySQL账号创建与权限分配的专业方法。 一、为何需要创建独立账号? 最小权限原则…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
QT3D学习笔记——圆台、圆锥
类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体(对象或容器)QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质(定义颜色、反光等)QFirstPersonC…...
FFmpeg:Windows系统小白安装及其使用
一、安装 1.访问官网 Download FFmpeg 2.点击版本目录 3.选择版本点击安装 注意这里选择的是【release buids】,注意左上角标题 例如我安装在目录 F:\FFmpeg 4.解压 5.添加环境变量 把你解压后的bin目录(即exe所在文件夹)加入系统变量…...
PHP 8.5 即将发布:管道操作符、强力调试
前不久,PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5!作为 PHP 语言的又一次重要迭代,PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是,借助强大的本地开发环境 ServBay&am…...
OD 算法题 B卷【正整数到Excel编号之间的转换】
文章目录 正整数到Excel编号之间的转换 正整数到Excel编号之间的转换 excel的列编号是这样的:a b c … z aa ab ac… az ba bb bc…yz za zb zc …zz aaa aab aac…; 分别代表以下的编号1 2 3 … 26 27 28 29… 52 53 54 55… 676 677 678 679 … 702 703 704 705;…...
CVPR2025重磅突破:AnomalyAny框架实现单样本生成逼真异常数据,破解视觉检测瓶颈!
本文介绍了一种名为AnomalyAny的创新框架,该方法利用Stable Diffusion的强大生成能力,仅需单个正常样本和文本描述,即可生成逼真且多样化的异常样本,有效解决了视觉异常检测中异常样本稀缺的难题,为工业质检、医疗影像…...
提升移动端网页调试效率:WebDebugX 与常见工具组合实践
在日常移动端开发中,网页调试始终是一个高频但又极具挑战的环节。尤其在面对 iOS 与 Android 的混合技术栈、各种设备差异化行为时,开发者迫切需要一套高效、可靠且跨平台的调试方案。过去,我们或多或少使用过 Chrome DevTools、Remote Debug…...
