JavaScript教程:使用矩阵创建列表的方法
P粉617237727
P粉617237727 2023-09-06 09:54:44
0
2
599
<p><strong>我有一个像这样的吞吐量</strong></p> <pre class="brush:php;toolbar:false;">const input_array= [ [“黑色”、“蓝色”]、 [“大”、“中”]、 [“a”、“b”、“c”] //...是否动态可以添加很多行 ];</前> <p><strong>我得到了一个像这样的吞吐量:</strong></p>
const Finallist = [
    [“黑色”、“大”、“a”]、
    [“黑色”、“大”、“b”]、
    [“黑色”、“大”、“c”]、
      
    [“黑色”、“中”、“a”]、
    [“黑色”、“中”、“b”]、
    [“黑色”、“中”、“c”]、

    [“蓝色”、“大”、“a”]、
    [“蓝色”、“大”、“b”]、
    [“蓝色”、“大”、“c”]、
      
    [“蓝色”、“中”、“a”]、
    [“蓝色”、“中”、“b”]、
    [“蓝色”、“中”、“c”]、
  ]</pre>
<p><strong>请记住input_array是动态的</strong></p>
<p><strong>请告诉我如何做到这一点</strong></p>            
P粉617237727
P粉617237727

全部回复(2)
P粉729518806

你可以像这样做:

const input_array = [
    ["black", "blue"],
    ["large", "medium"],
    ["a", "b", "c"]
]
const getCompinations = array =>
  array.reduce((v, b) =>
    v.reduce((r, g) => [...r, ...b.map(w => [].concat(g, w))], [])
  )
console.log(getCompinations(input_array))
P粉449281068

看一下这个,可能会有帮助:

const input_array = [
    ["black", "blue"],
    ["large", "medium"],
    ["a", "b", "c"]
    //... 是否可以动态添加多行
];
const mmc = input_array.reduce((e, r) => e * r.length, 1);
const finallist = input_array.map((x,i)=>({index:i,arr:x})).reduce((e, r) => {
    for (var u = 0; u  e[u].includes(r)) || e[u].length 

小心! 在大规模矩阵中可能会导致浏览器崩溃。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板