define(["./query", "./_base/lang", "./html"], function(query, lang, html){ // module: // dojo/NodeList-html /*===== return function(){ // summary: // Adds a chainable html method to dojo/query() / NodeList instances for setting/replacing node content }; =====*/ var NodeList = query.NodeList; lang.extend(NodeList, { html: function(/* String|DomNode|NodeList? */ content, /* Object? */params){ // summary: // see `dojo/html.set()`. Set the content of all elements of this NodeList // // content: // An html string, node or enumerable list of nodes for insertion into the dom // // params: // Optional flags/properties to configure the content-setting. See dojo/html._ContentSetter // // description: // Based around `dojo/html.set()`, set the content of the Elements in a // NodeList to the given content (string/node/nodelist), with optional arguments // to further tune the set content behavior. // // example: // | require(["dojo/query", "dojo/NodeList-html" // | ], function(query){ // | query(".thingList").html("<li data-dojo-type='dojo/dnd/Moveable'>1</li><li data-dojo-type='dojo/dnd/Moveable'>2</li><li data-dojo-type='dojo/dnd/Moveable'>3</li>", // | { // | parseContent: true, // | onBegin: function(){ // | this.content = this.content.replace(/([0-9])/g, this.id + ": $1"); // | this.inherited("onBegin", arguments); // | } // | }).removeClass("notdone").addClass("done"); // | }); var dhs = new html._ContentSetter(params || {}); this.forEach(function(elm){ dhs.node = elm; dhs.set(content); dhs.tearDown(); }); return this; // dojo/NodeList } }); return NodeList; });