data:image/s3,"s3://crabby-images/f65d6/f65d679d5a7510de944eabf45fe79721afb407d4" alt=""
1. 数据生成流程
data:image/s3,"s3://crabby-images/62b12/62b1220f55c06fe4b26e992be6b0e6bfc646dfaa" alt=""
规格类型数据:
// JSON
[
{
"key": 1,
"name": "尺寸",
"labels": [
{ "key": 1, "value": "M" },
{ "key": 2, "value": "XL" },
{ "key": 3, "value": "XXL" }
]
},
{
"key": 2,
"name": "颜色",
"labels": [
{ "key": 1, "value": "红" },
{ "key": 2, "value": "蓝" },
]
},
{
"key": 3,
"name": "款式",
"labels": [
{ "key": 1, "value": "男款" }
]
}
]
2. 计算全排列组合的所有可能的结果:
function calc(transArr) {
let resultArr = [];
function get(array, index, val) {
if (!array[index]) {
resultArr.push(val);
return;
}
array[index].forEach((v, i) => {
get(array, index + 1, index === 0 ? [v] : [...val, v])
})
}
get(transArr, 0);
return resultArr;
}
// 输出
// [
// ["M","红","男款"],
// ["M","蓝","男款"],
// ["XL","红","男款"],
// ["XL","蓝","男款"],
// ["XXL","红","男款"],
// ["XXL","蓝","男款"]
// ]
初始化为可用的列表数据:
data:image/s3,"s3://crabby-images/12224/1222485c28d8ac6287ae205974234e7a23885ad2" alt=""
3. 可能出现的问题
规格类型发生变动,会重新排列规格组合结果,然后初始化一次列表数据,之前填充的数据会被清空,交互体验差。
友商参照:荟集云 - 荟集科技
解决方法
data:image/s3,"s3://crabby-images/b6270/b62704e2893882e9ddd5a68d2eff5bab5e88824f" alt=""
(1). 定义tag标记,生成所有排列结果:
[
["1/1:M","2/1:红","3/1:男款"],
["1/1:M","2/2:蓝","3/1:男款"],
["1/2:XL","2/1:红","3/1:男款"],
["1/2:XL","2/2:蓝","3/1:男款"],
["1/3:XXL","2/1:红","3/1:男款"],
["1/3:XXL","2/2:蓝","3/1:男款"]
]
(2). 组合tag值,生成Map类型数据保存,使该条SKU数据唯一:
let tableMap = list.reduce((res, item, index) => {
res[item.tag] = item
return res
}, {})
data:image/s3,"s3://crabby-images/2be60/2be60b2ead27a33bc4b05ade03b37d63ae7ef3e4" alt=""
(3). 初始化表格数据时,优先查找Map类型数据,找到即取出与之合并,反之即为新数据:
添加一个【颜色:黑】的规格值,按序排列。
data:image/s3,"s3://crabby-images/b19a1/b19a1d2ecbb37168d8c67f220c1ae1fc014c6ded" alt=""
未来可能要做的
data:image/s3,"s3://crabby-images/c9e7d/c9e7d065bfd81da440214d37360a73f79de3a0b0" alt=""
参考文章