如何对 dom 元素进行 JSON.stringify?

问题描述 投票:0回答:4

如 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":[...]}
javascript dom
4个回答
18
投票

我认为最合理的方法是将要序列化的 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
),则可能需要在替换函数中进行一些额外的工作。


7
投票

我也想知道同样的事情,我很感谢@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
投票

老问题,但无论如何,我处于同样的情况,当你可以访问你需要的元素并且你只想要它的 html 时。事实证明,我们需要做的就是获取 DOM 对象的 externalHTML 属性的内容。这会为您提供一个字符串,您可以将其作为值放入 JSON 中,也可以不放入。

let HTML = container.outerHTML


1
投票

尽管这是一个旧线程,但这是我的补充:

JSON.stringify(target, Object.getOwnPropertyNames(target["__proto__"]), 2)

为您提供 DOM 元素的一些属性的快速列表。

© www.soinside.com 2019 - 2024. All rights reserved.