欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 会展 > js es6 reduce函数, 通过规格生成sku

js es6 reduce函数, 通过规格生成sku

2025/1/9 4:12:57 来源:https://blog.csdn.net/u010843503/article/details/144886466  浏览:    关键词:js es6 reduce函数, 通过规格生成sku
const specs = [{ name: '颜色', values: ['红色', '蓝色', '绿色'] },{ name: '尺寸', values: ['S', 'M', 'L'] }
];function generateSKUs(specs) {return specs.reduce((acc, spec) => {const newAcc = [];for (const combination of acc) {for (const value of spec.values) {newAcc.push({ ...combination, [spec.name]: value });}}return newAcc;}, [{}]); // 初始值是一个空对象数组
}const skus = generateSKUs(specs);
console.log(skus);

输出的值显示

[{ 颜色: '红色', 尺寸: 'S' },{ 颜色: '红色', 尺寸: 'M' },{ 颜色: '红色', 尺寸: 'L' },{ 颜色: '蓝色', 尺寸: 'S' },{ 颜色: '蓝色', 尺寸: 'M' },{ 颜色: '蓝色', 尺寸: 'L' },{ 颜色: '绿色', 尺寸: 'S' },{ 颜色: '绿色', 尺寸: 'M' },{ 颜色: '绿色', 尺寸: 'L' }
]

参数说明

accumulator:累加器累积回调的返回值。
currentValue:当前处理的数组元素。
index(可选):当前处理的数组元素的索引。
array(可选):调用reduce()方法的数组本身。
initialValue(可选):作为第一次调用callback函数时accumulator参数的值。
-------------------------
acc, spec 上方这两个参数就是这个意思acc累加器累积回调的返回值,第一次会返回空数据,也就是尾部定义的 [{ }]定义0或者其他就会返回其他,后面也会返回相同类型,记得一定要写return就行spec  当前行数据 类似map 返回的

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com