所以,我试图从一个数组中选择一个随机条目,然后进行设置,以便在选择每个条目之前不会再次选择特定条目.
基本上,我不希望看到任何相同的条目,直到选择了数组中的所有条目.
基本上,我不希望看到任何相同的条目,直到选择了数组中的所有条目.
所以,如果这是我的阵…
- keywords =
- [
- "ppc","games","advertise","Meta","home","gaming","welcome"
- ]
- var keyword = keywords[Math.floor(Math.random()*keywords.length)]
- document.write(keyword);
我不希望看到输出:
因为Meta在第二次被选中之后才被选中.
我想看到更像的东西:
- Meta,games,
因为在每个条目被随机选择之前没有多次选择任何条目.(第二个循环从第二个“广告”开始,以防你没有发现差异.
但是你可以从我上面发布的代码中看到,我不知道该怎么做.我已经看到了随机选择的条目实际上从数组中完全删除的示例,但这不是我想要做的.我只想要选择每个条目一次,然后重新启动进程.
有谁知道这个代码?
解决方法
您可以使用Array.sort()函数对其进行随机排序.
- // random sort function
- function shuffle(a,b)
- {
- return Math.random() > 0.5 ? -1 : 1;
- }
- var keywords = ["ppc","welcome"];
- var randomKeywords = keywords.sort(shuffle); // new instance of a sorted randomly copy of the array
- alert(randomKeywords);
更新:
一个更好的改组解决方案是使用Fisher-Yates Shuffle,如answer所示.
- function shuffle(array)
- {
- var m = array.length,t,i;
- while (m > 0)
- {
- i = Math.floor(Math.random() * m--);
- t = array[m];
- array[m] = array[i];
- array[i] = t;
- }
- return array;
- }
- var keywords = ["ppc","welcome"];
- shuffle(keywords); // shuffles the array
- alert(keywords);