vue通過(guò)笛卡兒積實(shí)現(xiàn)sku庫(kù)存配置方式
vue通過(guò)笛卡兒積實(shí)現(xiàn)sku庫(kù)存配置
目標(biāo)
通過(guò)頁(yè)面上渲染出來(lái)的動(dòng)態(tài)屬性 實(shí)現(xiàn)sku庫(kù)存配置
將已選擇的所有屬性,通過(guò)笛卡兒積實(shí)現(xiàn)sku庫(kù)存配置
以兩個(gè)屬性為例子,舉例說(shuō)明:
1x1:
白色
S
結(jié)合之后就是
[白色,S]
?this.selectCheckArr=[ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ] ] ?this.selectCheckArr = this.getProducts(this.selectCheckArr) ?console.log(this.selectCheckArr) ?/** 輸出:[ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ] ] **/
1x2
白色 黃色
S
結(jié)合之后就是
[白色,S ],[黃色,S ]
?this.selectCheckArr=[ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 01, ? ? ? ? ? ? "attrValueName": "黃色" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ] ] ?this.selectCheckArr = this.getProducts(this.selectCheckArr) ?console.log(this.selectCheckArr) ?/** 輸出:? ?[ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 01, ? ? ? ? ? ? "attrValueName": "黃色" ? ? ? ? }, ? ? ? ?{ ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ] ] **/
2x2
白 黃
S M
結(jié)合之后就是
[白色,S ],[白色,M ],[黃色,S ],[黃色,M ]
?this.selectCheckArr= [ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 01, ? ? ? ? ? ? "attrValueName": "黃色" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 12, ? ? ? ? ? ? "attrValueName": "M" ? ? ? ? } ? ? ] ] ?this.selectCheckArr = this.getProducts(this.selectCheckArr) ?console.log(this.selectCheckArr) ?/** 輸出:? ?[ ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 00, ? ? ? ? ? ? "attrValueName": "白色" ? ? ? ? }, ? ? ? ? { ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 12, ? ? ? ? ? ? "attrValueName": "M" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? ?{ ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 01, ? ? ? ? ? ? "attrValueName": "黃色" ? ? ? ? }, ? ? ? ? ?{ ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 11, ? ? ? ? ? ? "attrValueName": "S" ? ? ? ? } ? ? ], ? ? [ ? ? ? ? { ? ? ? ? ? ? "attrId": 0, ? ? ? ? ? ? "attrName": "顏色", ? ? ? ? ? ? "attrValueId": 01, ? ? ? ? ? ? "attrValueName": "黃色" ? ? ? ? }, ? ? ? ?{ ? ? ? ? ? ? "attrId": 1, ? ? ? ? ? ? "attrName": "大小", ? ? ? ? ? ? "attrValueId": 12, ? ? ? ? ? ? "attrValueName": "M" ? ? ? ? } ? ? ] ] **/
笛卡兒積方法
? ? // 笛卡兒積 ? ? ? getProducts(specs) { ? ? ? ? if (!specs || specs.length == 0) { ? ? ? ? ? return []; ? ? ? ? } else { ? ? ? ? ? return joinSpec([ ? ? ? ? ? ? [] ? ? ? ? ? ], specs, 0, specs.length - 1); ? ? ? ? } ? ? ? ? function joinSpec(prevProducts, specs, i, max) { ? ? ? ? ? var currentProducts = [], ? ? ? ? ? ? currentProduct, currentSpecs = specs[i]; ? ? ? ? ? if (i > max) { ? ? ? ? ? ? return prevProducts; ? ? ? ? ? } ? ? ? ? ? prevProducts.forEach(function (prevProduct) { ? ? ? ? ? ? currentSpecs.forEach(function (spec) { ? ? ? ? ? ? ? currentProduct = prevProduct.slice(0); ? ? ? ? ? ? ? currentProduct.push(spec); ? ? ? ? ? ? ? currentProducts.push(currentProduct); ? ? ? ? ? ? }); ? ? ? ? ? }); ? ? ? ? ? return joinSpec(currentProducts, specs, ++i, max); ? ? ? ? } ? ? ? },
注意
this.getProducts()的入?yún)ⅲ枧c博主保持一致(數(shù)組對(duì)象),否則會(huì)有問(wèn)題哦~
如果是1x1 ,就是總共生成1條
[ [ { } ] , [ { } ] ],變成 [ [ { } , { } ] ]
如果是2x1 ,就是總共生成2條
[ [ { } ,{ } ] , [ { } ] ] 變成 [ [ { } ,{ } ] , [ { } ,{ } ] ]
笛卡爾積生成商品SKU組合
var arr = [ ['黑色', '白色', '藍(lán)色'], ['8GB', '16GB', '32GB'], ['大', '中', '小'] ]; /** * 生成笛卡爾積 * @returns {*} */ function descartes(array) { if (array.length < 2) return array[0] || []; return [].reduce.call(array, function (col, set) { var res = []; col.forEach(function (c) { set.forEach(function (s) { var t = [].concat(Array.isArray(c) ? c : [c]); t.push(s); res.push(t); }) }); return res; }); } console.log(descartes(arr));
該方法用于根據(jù)商品規(guī)格屬性生成商品SKU組合,以上為javascript代碼
執(zhí)行結(jié)果如下:
0: ["黑色", "8GB", "大"]
1: ["黑色", "8GB", "中"]
2: ["黑色", "8GB", "小"]
3: ["黑色", "16GB", "大"]
4: ["黑色", "16GB", "中"]
5: ["黑色", "16GB", "小"]
6: ["黑色", "32GB", "大"]
7: ["黑色", "32GB", "中"]
8: ["黑色", "32GB", "小"]
9: ["白色", "8GB", "大"]
10: ["白色", "8GB", "中"]
11: ["白色", "8GB", "小"]
12: ["白色", "16GB", "大"]
13: ["白色", "16GB", "中"]
14: ["白色", "16GB", "小"]
15: ["白色", "32GB", "大"]
16: ["白色", "32GB", "中"]
17: ["白色", "32GB", "小"]
18: ["藍(lán)色", "8GB", "大"]
19: ["藍(lán)色", "8GB", "中"]
20: ["藍(lán)色", "8GB", "小"]
21: ["藍(lán)色", "16GB", "大"]
22: ["藍(lán)色", "16GB", "中"]
23: ["藍(lán)色", "16GB", "小"]
24: ["藍(lán)色", "32GB", "大"]
25: ["藍(lán)色", "32GB", "中"]
26: ["藍(lán)色", "32GB", "小"]
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-cli 3.x 配置Axios(proxyTable)跨域代理方法
今天小編就為大家分享一篇vue-cli 3.x 配置Axios(proxyTable)跨域代理方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09Vue3+Antd實(shí)現(xiàn)彈框顯示內(nèi)容并加入復(fù)制按鈕
這篇文章主要介紹了Vue3+Antd實(shí)現(xiàn)彈框顯示內(nèi)容并加入復(fù)制按鈕,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-12-12Vue+Element實(shí)現(xiàn)表格編輯、刪除、以及新增行的最優(yōu)方法
這篇文章主要為大家詳細(xì)介紹了Vue+Element實(shí)現(xiàn)表格的編輯、刪除、以及新增行的最優(yōu)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05在 Typescript 中使用可被復(fù)用的 Vue Mixin功能
這篇文章主要介紹了在 Typescript 中使用可被復(fù)用的 Vue Mixin功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-04-04用vue3封裝一個(gè)符合思維且簡(jiǎn)單實(shí)用的彈出層
最近新項(xiàng)目中需要一個(gè)彈窗組件,所以我就做了一個(gè),下面這篇文章主要給大家介紹了關(guān)于如何利用vue3封裝一個(gè)符合思維且簡(jiǎn)單實(shí)用的彈出層,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05Vue數(shù)據(jù)增刪改查與表單驗(yàn)證的實(shí)現(xiàn)流程介紹
這篇文章主要介紹了Vue數(shù)據(jù)增刪改查與表單驗(yàn)證的實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-10-10Vue中瀑布流布局與圖片加載優(yōu)化的實(shí)現(xiàn)
本文主要介紹了Vue中瀑布流布局與圖片加載優(yōu)化的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06Vue2.0+Vux搭建一個(gè)完整的移動(dòng)webApp項(xiàng)目的示例
這篇文章主要介紹了Vue2.0+Vux搭建一個(gè)完整的移動(dòng)webApp項(xiàng)目的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-03-03vue使用exif獲取圖片旋轉(zhuǎn),壓縮的示例代碼
這篇文章主要介紹了vue使用exif獲取圖片旋轉(zhuǎn),壓縮的示例代碼,幫助大家更好的利用python處理圖片,感興趣的朋友可以了解下2020-12-12