如 title ,如何将 dom 元素 JSON.stringify,并将 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
如果您也想序列化其子节点,则需要一些额外的工作。在这种情况下,您必须指定替换函数作为
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
),则可能需要在替换函数中进行一些额外的工作。
我也想知道同样的事情,我很感谢@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>
老问题,但无论如何,我处于同样的情况,当你可以访问你需要的元素并且你只想要它的 html 时。事实证明,我们需要做的就是获取 DOM 对象的 externalHTML 属性的内容。这会为您提供一个字符串,您可以将其作为值放入 JSON 中,也可以不放入。
let HTML = container.outerHTML
尽管这是一个旧线程,但这是我的补充:
JSON.stringify(target, Object.getOwnPropertyNames(target["__proto__"]), 2)
为您提供 DOM 元素的一些属性的快速列表。