如何JSON.stringify一个dom元素?

时间:2017-10-23 01:31:14

标签: javascript dom

作为标题,如何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":[...]}

3 个答案:

答案 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元素的某些属性。