java script html_如何用Java Script将HTML重新排序

可以用类数组方法排序后都进行一次 appendChild 移位。const mylist = document.getElementById('mylist');

[ ...mylist.children ]

.sort((a, b) => Number(a.id) - Number(b.id))

.forEach((ele) => {

mylist.appendChild(ele);

});

其中,[ ...foo ] 是 Array.from(foo) 的简写。forEach 方法是按首项到末项的顺序执行的,这在 ECMAScript 标准中有明确定义,可以放心使用。forEach calls callbackfn once for each element present in the array, in ascending order.

而 appendChild 负责把元素放到被 append 元素的子元素的最后。这样,按顺序依次把每子项放最后,就成按顺序排布的状态了。

但是,不推荐以 id 的方式来设定元素顺序。你可以使用自定义属性 data-* 这一类。

  • text 2
  • text 3
  • text 1

然后使用 dataset 属性在 JavaScript 中访问。参阅 data-* - HTML(超文本标记语言) | MDN。const mylist = document.getElementById('mylist');

[ ...mylist.children ]

.sort((a, b) => Number(a.dataset.order) - Number(b.dataset.order))

.forEach((ele) => {

mylist.appendChild(ele);

});

另外,直接操作 DOM 的性能花销比较大,更为建议使用 CSS 中 flex 元素 order 属性的特点,改变显示顺序。 参阅 Flex项排序 - CSS(层叠样式表) | MDN。#mylist {

display: flex;

flex-direction: column;

}const mylist = document.getElementById('mylist');

[ ...mylist.children ].forEach((ele) => {

ele.style.setProperty('order', ele.dataset.order);

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值