I want to serialize DOM node or even whole window
to JSON.
For example:
>> serialize(document)
-> {
"URL": "http://stackoverflow.com/posts/2303713",
"body": {
"aLink": "",
"attributes": [
"getNamedItem": "function getNamedItem() { [native code] }",
...
],
...
"ownerDocument": "#" // recursive link here
},
...
}
JSON.stringify()
JSON.stringify(window) // TypeError: Converting circular structure to JSON
The problem is JSON does not support circular references by default.
var obj = {}
obj.me = obj
JSON.stringify(obj) // TypeError: Converting circular structure to JSON
window
and DOM nodes have many of them. window === window.window
as will as document.body.ownerDocument === document
.
Also, JSON.stringify
does not serialize functions, so this is not what I'm looking for.
dojox.json.ref
`dojox.json.ref.toJson()` can easily serialize object with circular references:
var obj = {}
obj.me = obj
dojox.json.ref.toJson(obj); // {"me":{"$ref":"#"}}
Good, isn't it?
dojox.json.ref.toJson(window) // Error: Can't serialize DOM nodes
Well not good enough for me.
Why?
I'm trying to make DOM compatibility table for different browsers. For instance, Webkit supports placeholder attribute and Opera doesn't, IE 8 supports localStorage
and IE 7 doesn't, and so on.
I don't want to make thousands of test-cases. I want to make generic way for test them all.
Update, June 2013
I made a prototype NV/dom-dom-dom.com.
http://jsonml.org/ takes a shot at a grammar for converting XHTML DOM elements into JSON. An an example:
becomes
Haven't used it yet, but thinking about using it for a project where I want to take any web page and re-template it using mustache.js.
I found this and it worked great for me when I was trying to convert an XML string into JSON.
Maybe it will help.
You could potentially traverse the DOM and generate a pure JS object representation of it and then feed it to the DojoX serializer. But, you have to first decide how you're planning to map DOM elements, their attributes and the text nodes, without ambiguity, to JS objects. For example, how would you represent the following?
Like this?
I think the a reason DojoX doesn't immediately support DOM serialization could exactly be this: The need to first pick a scheme for mapping DOM to JS objects. Is there a standard scheme that could be employed? Would your JS object simply mimic a DOM tree without any functions? I think you have to first define what your expectation is from "serializing DOM to JSON".
It looks like you have to write it on your own. JSON serialized data may also not be the perfect choice for your task (DOM compatibility table). You probably have to iterate the objects on your own, check types of the attributes and so on..