javascript - 打乱 HTML 列表元素的顺序

标签 javascript html html-lists

我有一个列表:

<ul>
    <li>milk</li>
    <li>butter</li>
    <li>eggs</li>
    <li>orange juice</li>
    <li>bananas</li>
</ul>

如何使用 javascript 随机重新排序列表项?

最佳答案

var ul = document.querySelector('ul');
for (var i = ul.children.length; i >= 0; i--) {
    ul.appendChild(ul.children[Math.random() * i | 0]);
}

这是基于Fisher–Yates shuffle ,并利用了这样一个事实,即当您附加一个节点时,它会从原来的位置移走。

即使在巨大的列表(100 000 个元素)上,性能也在 10% 以内。

http://jsfiddle.net/qEM8B/

关于javascript - 打乱 HTML 列表元素的顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7070054/

相关文章:

javascript - Google 脚本 - 从网站论坛解析 HTML - 并将数据写入工作表

JavaScript 淡入淡出

javascript - HTTP 请求方法和 AJAX。到底是怎么回事?

php - 将 PHP 重定向到登录页面,而不是强制登录

css - 我的列表没有正确对齐并且不确定如何修复

javascript - 如何从下拉列表和范围内的点中找到选定的li?

javascript - 如何在 Javascript/JQuery 或 AngularJS 中清除浏览器缓存

html - 如何将缩略图照片添加到 ruby​​ on rails 中的页眉?

javascript - 使用 <p> 标签包装 JQuery 函数结果

python - BeautifulSoup 找不到标签 li