
本文介绍了如何在 JavaScript 中高效地交换两个 DOM 元素的部分属性,重点关注 data-* 属性的交换。通过创建属性对象的副本,避免了直接修改原始属性引用导致的问题。同时,探讨了 dataset 属性的局限性,并提供了一种可行的解决方案。
在某些场景下,我们需要交换两个 DOM 元素的部分属性,而不是全部属性。例如,我们可能只想交换以 data-keep- 开头的自定义数据属性。以下代码展示了如何实现这一目标:
function swapAttributes(el1, el2) {
// 保存需要保留的数据
const el1Keeps = [],
el2Keeps = [];
[...el1.attributes].forEach(attr => {
if (attr.nodeName.startsWith("data-keep-")) {
el1Keeps.push({
name: attr.name,
value: attr.value
});
}
});
[...el2.attributes].forEach(attr => {
if (attr.nodeName.startsWith("data-keep-")) {
el2Keeps.push({
name: attr.name,
value: attr.value
});
}
});
// 将属性设置到另一个元素上
el2Keeps.forEach(keepAttr => {
el1.setAttribute(keepAttr.name, keepAttr.value)
})
el1Keeps.forEach(keepAttr => {
el2.setAttribute(keepAttr.name, keepAttr.value)
})
}
let elem1 = document.getElementById("item1");
let elem2 = document.getElementById("item2");
let before = document.getElementById("before");
let after = document.getElementById("after");
before.innerHTML = 'before: ' + showData(elem1, elem2);
swapAttributes(elem1, elem2);
after.innerHTML = 'after: ' + showData(elem1, elem2);
function showData(a, b) {
let data1 = a.dataset;
let data2 = b.dataset;
return data1.keepRow + "," + data1.keepCol + " and " + data2.keepRow + "," + data2.keepCol;
}代码解释:
HTML 示例:
立即学习“Java免费学习笔记(深入)”;
<div id="item1" data-keep-row=1 data-keep-col=1>item1</div> <div id="item2" data-keep-row=2 data-keep-col=2>item2</div> <p id="before"></p> <p id="after"></p>
通过创建属性对象的副本,我们可以安全地交换 DOM 元素的部分属性,避免了直接修改原始属性引用导致的问题。虽然 dataset 属性提供了一种方便的方式来访问 data-* 属性,但它具有只读的局限性。在实际应用中,需要根据具体情况选择合适的解决方案。 这种方法可以应用于更广泛的属性交换场景,只需修改属性过滤条件即可。
以上就是JavaScript 中交换两个元素的部分属性的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号