javascript – 如何JSON.stringify一个dom元素?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何JSON.stringify一个dom元素?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1479字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 如何JSON.stringify一个dom元素?](/upload/InfoBanner/zyjiaocheng/705/3f269829b472453ea575512039616b70.jpg)
作为标题,如何JSON.stringify一个dom元素,并将json更改为dom元素.
任何人都知道怎么做,谢谢.
Here is the code :
var container = document.querySelectorAll('.container')
var json=JSON.stringify(container)
{"0":{},"1":{},"2":{},"3":{}}"//result
expected result:
{"tagname":"div","class":"container","value":"test","childelement":[...]}
解决方法:
我认为最合理的方法是将要序列化的DOM元素的哪些属性列入白名单:
JSON.stringify(container, ["id", "className", "tagName"])
JSON.stringify函数的第二个参数允许您更改字符串化过程的行为.您可以使用要序列化的属性列表指定一个数组.更多信息:JSON.stringify
如果您想要序列化其子节点,还需要一些额外的工作.在这种情况下,您必须将replacer函数指定为JSON.stringify的第二个参数,而不是数组.
let whitelist = ["id", "tagName", "className", "childNodes"];
function domToObj (domEl) {
var obj = {};
for (let i=0; i<whitelist.length; i++) {
if (domEl[whitelist[i]] instanceof NodeList) {
obj[whitelist[i]] = Array.from(domEl[whitelist[i]]);
}
else {
obj[whitelist[i]] = domEl[whitelist[i]];
}
};
return obj;
}
JSON.stringify(container, function (name, value) {
if (name === "") {
return domToObj(value);
}
if (Array.isArray(this)) {
if (typeof value === "object") {
return domToObj(value);
}
return value;
}
if (whitelist.find(x => (x === name)))
return value;
})
replacer函数将childNodes中的托管对象转换为本机对象,JSON.stringify知道如何序列化.白名单数组包含要序列化的属性列表.您可以在此处添加自己的属性.
如果要序列化引用托管对象的其他属性(例如,firstChild),则可能需要在replacer函数中执行一些额外的工作.
内容总结
以上是互联网集市为您收集整理的javascript – 如何JSON.stringify一个dom元素?全部内容,希望文章能够帮你解决javascript – 如何JSON.stringify一个dom元素?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。