I have created a small JavaScript toolkit named e4x-dom.js for making it easy to manipulate the DOM with E4X.
The following methods are implemented on XML objects by e4x-dom.js:
node()
- Returns the HTML node representation of the XML.
over(element or selector)
- Either overwrites
element
or every element matched by the CSS selector withnode()
. overId(id)
- Same as
over(document.getElementById(id))
but also preserves the the id of the element being overwritten in the element replacing it. fill(element or selector)
- Removes every child node of
element
or every element matched by the CSS selector. Thennode()
is appended to all of the emptied elements. fillId(id)
- Same as
fill(document.getElementById(id))
appendTo(element or selector)
- Appends
node()
toelement
or every element matched by the CSS selector. appendToId(id)
- Same as
appendTo(document.getElementById(id))
. insertBefore(element or selector)
- Inserts
node()
beforeelement
or every element matched by the CSS selector. insertBeforeId(id)
- Same as
insertBefore(document.getElementById(id))
. insertAfter(element or selector)
- Inserts
node()
afterelement
or every element matched by the CSS selector. insertAfterId(id)
- Same as
insertAfter(document.getElementById(id))
.
The following are examples of using the toolkit:
var img = <img src={prompt("Enter an image URI")} alt={prompt("Describe the image")} id="foobar" />; img.appendTo(document.body); <h1>The image was <em>removed</em>.</em>.overId("foobar"); <![CDATA[And then this text node filled the header]]>.fill("#foobar"); // the CDATA isn't itself put into the document but the data inside it is escaped so it // works in HTML and XHTML <h1><![CDATA[<html> in here is <escaped>]]></h1>.insertBefore(document.body.firstChild); // if you just want to create an element quickly, do xml.node() <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"/>.node(); // SVG node <div/>.node(); // div node // DOM methods are forwarded to .node()[method]() <canvas/>.getContext("2d"); <foo bar="baz"/>.getAttribute("bar") === "baz"; // same as getting .@bar // mass-modifications with CSS selectors <strong>Absolute links are <em>not</em> allowed</strong> .over('a[href^="http://"], a[href^="https://"], a[href^="//"]'); if (user.hasEditPrivileges) { // wikipedia-style "put an edit link at the start of each section" <a href={"/edit?page=" + page.id}>[edit]</a>.insertAfter('h2'); } // <![CDATA[]]> nodes directly accessed are converted to text nodes: <![CDATA[ This is a text node. <html> is escaped inside it. ]]>.appendTo("#some-element"); |
Sounds interesting.
But: Which Browsers support your lib, only Mozilla ?
And have you somewhere an online demo ?
Regards
Rusco
Only SpiderMonkey, Rhino (both maintained by Mozilla), and Tamarin (maintained by Adobe) support E4X. As for the demo, just try out the examples in the post.
Know this is old, but the link doesn’t work.