recherche

Maison  >  Questions et réponses  >  le corps du texte

Tutoriel JavaScript : Comment créer une liste à l'aide d'une matrice

<p><strong>我有一个像这样的数组</strong></p> <pre class="brush:php;toolbar:false;">const input_array= [ ["noir", "bleu"], ["grand", "moyen"], ["a", "b", "c"] //... est-ce dynamique, peut-on ajouter plusieurs lignes ];≪/pré> <p><strong>我该如何得到一个像这样的数组:</strong></p> <pre class="brush:php;toolbar:false;">const finallist = [ ["noir", "grand", "a"], ["noir", "grand", "b"], ["noir", "grand", "c"], ["noir", "moyen", "a"], ["noir", "moyen", "b"], ["noir", "moyen", "c"], ["bleu", "grand", "a"], ["bleu", "grand", "b"], ["bleu", "grand", "c"], ["bleu", "moyen", "a"], ["bleu", "moyen", "b"], ["bleu", "moyen", "c"], ]≪/pré> <p><strong>请记住input_array是动态的</strong></p> <p><strong>请告诉我如何做到这一点</strong></p>
P粉617237727P粉617237727447 Il y a quelques jours575

répondre à tous(2)je répondrai

  • P粉729518806

    P粉7295188062023-09-07 09:34:40

    Vous pouvez faire quelque chose comme ceci :

    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))
    

    répondre
    0
  • P粉449281068

    P粉4492810682023-09-07 00:39:31

    Jetez un œil à ceci, cela pourrait aider :

    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 < mmc; u++) e[u] && (!r.arr.some(r => e[u].includes(r)) || e[u].length <= r.index) ? e[u].push(r.arr[u % r.arr.length]) : e.push([r.arr[u % r.arr.length]]);
        return e.sort(), e
    }, []);
    

    Soyez prudent ! Peut provoquer un crash du navigateur dans une grande matrice.

    répondre
    0
  • Annulerrépondre