作为标题,如何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":[...]}
答案 0 :(得分:5)
我认为最合理的方法是将要序列化的DOM元素的哪些属性列入白名单:
JSON.stringify(container, ["id", "className", "tagName"])
JSON.stringify
函数的第二个参数允许您更改字符串化过程的行为。您可以使用要序列化的属性列表指定一个数组。更多信息请访问:JSON.stringify
如果您想要序列化其子节点,还需要一些额外的工作。在这种情况下,您必须将替换器函数指定为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
知道如何序列化。 whitelist
数组包含要序列化的属性列表。您可以在此处添加自己的属性。
如果要序列化引用托管对象的其他属性(例如,firstChild
),则可能需要在replacer函数中执行一些额外的工作。
答案 1 :(得分:0)
我想知道同样的事情,并且感谢@ncardeli的回答。在我的应用程序中,我需要一些不同的东西,我想分享一下,以防有人感兴趣。它也递归地显示所有子级的属性。
按下面的按钮运行示例。您可以将任何想要的属性添加到obj,从而添加到结果中。
function showStringifyResult(target) {
let result = document.getElementById("result");
result.select();
result.setRangeText(JSON.stringify(stringify(target), null, ' '));
}
function stringify(element) {
let obj = {};
obj.name = element.localName;
obj.attributes = [];
obj.children = [];
Array.from(element.attributes).forEach(a => {
obj.attributes.push({ name: a.name, value: a.value });
});
Array.from(element.children).forEach(c => {
obj.children.push(stringify(c));
});
return obj;
}
#list {
margin-top: 18px;
}
<h1>
Press the Stringify button to write the stringified object to the textarea below.
</h1>
<button onClick="showStringifyResult(document.body)" class="c1">
Stringify
</button>
<div id="list">
A list for example:
<ul class="first second">
<li id="First Item">Item 1</li>
<li>Item 2</li>
<li class="inactive">Item 3</li>
<li data-tag="tag">Item 4</li>
</ul>
</div>
<textarea id="result" cols="200" rows="20" ></textarea>
答案 2 :(得分:0)
即使这是旧主题,这也是我的补充:
JSON.stringify(target, Object.getOwnPropertyNames(target["__proto__"]), 2)
快速列出DOM元素的某些属性。