Difference between revisions of "User:Waldir/vector.js"
| Line 1: | Line 1: | ||
importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/vector.js&action=raw&ctype=text/javascript'); | importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/vector.js&action=raw&ctype=text/javascript'); | ||
| + | |||
| + | /** | ||
| + | * Create a new DOM node for the current document. | ||
| + | * Basic usage: var mySpan = newNode('span', "Hello World!") | ||
| + | * Supports attributes and event handlers*: var mySpan = newNode('span', {style:"color: red", focus: function(){alert(this)}, id:"hello"}, "World, Hello!") | ||
| + | * Also allows nesting to create trees: var myPar = newNode('p', newNode('b',{style:"color: blue"},"Hello"), mySpan) | ||
| + | * | ||
| + | * *event handlers, there are some issues with IE6 not registering event handlers on some nodes that are not yet attached to the DOM, | ||
| + | * it may be safer to add event handlers later manually. | ||
| + | **/ | ||
| + | function newNode(tagname){ | ||
| + | |||
| + | var node = document.createElement(tagname); | ||
| + | |||
| + | for( var i=1;i<arguments.length;i++ ){ | ||
| + | |||
| + | if(typeof arguments[i] == 'string'){ //Text | ||
| + | node.appendChild( document.createTextNode(arguments[i]) ); | ||
| + | |||
| + | }else if(typeof arguments[i] == 'object'){ | ||
| + | |||
| + | if(arguments[i].nodeName){ //If it is a DOM Node | ||
| + | node.appendChild(arguments[i]); | ||
| + | |||
| + | }else{ //Attributes (hopefully) | ||
| + | for(var j in arguments[i]){ | ||
| + | if(j == 'class'){ //Classname different because... | ||
| + | node.className = arguments[i][j]; | ||
| + | |||
| + | }else if(j == 'style'){ //Style is special | ||
| + | node.style.cssText = arguments[i][j]; | ||
| + | |||
| + | }else if(typeof arguments[i][j] == 'function'){ //Basic event handlers | ||
| + | newNode.addEventHandler(node, j, arguments[i][j]); | ||
| + | }else{ | ||
| + | node.setAttribute(j,arguments[i][j]); //Normal attributes | ||
| + | |||
| + | } | ||
| + | } | ||
| + | } | ||
| + | } | ||
| + | } | ||
| + | |||
| + | node.addEventHandler = | ||
| + | function(eventName, handler) | ||
| + | { newNode.addEventHandler(this, eventName, handler); }; | ||
| + | |||
| + | return node; | ||
| + | } | ||
| + | |||
| + | newNode.addEventHandler = function(node, eventName, handler) | ||
| + | { | ||
| + | try{ node.addEventListener(eventName,handler,false); //W3C | ||
| + | }catch(e){try{ node.attachEvent('on'+eventName,handler,"Language"); //MSIE | ||
| + | }catch(e){ node['on'+eventName]=handler; }} //Legacy | ||
| + | }; | ||
| + | |||
| + | importScriptURI('http://en.wiktionary.org/w/index.php?title=User:Yair rand/addcomment.js&action=raw&ctype=text/javascript'); | ||
Revision as of 08:16, 4 March 2013
importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/vector.js&action=raw&ctype=text/javascript');
/**
* Create a new DOM node for the current document.
* Basic usage: var mySpan = newNode('span', "Hello World!")
* Supports attributes and event handlers*: var mySpan = newNode('span', {style:"color: red", focus: function(){alert(this)}, id:"hello"}, "World, Hello!")
* Also allows nesting to create trees: var myPar = newNode('p', newNode('b',{style:"color: blue"},"Hello"), mySpan)
*
* *event handlers, there are some issues with IE6 not registering event handlers on some nodes that are not yet attached to the DOM,
* it may be safer to add event handlers later manually.
**/
function newNode(tagname){
var node = document.createElement(tagname);
for( var i=1;i<arguments.length;i++ ){
if(typeof arguments[i] == 'string'){ //Text
node.appendChild( document.createTextNode(arguments[i]) );
}else if(typeof arguments[i] == 'object'){
if(arguments[i].nodeName){ //If it is a DOM Node
node.appendChild(arguments[i]);
}else{ //Attributes (hopefully)
for(var j in arguments[i]){
if(j == 'class'){ //Classname different because...
node.className = arguments[i][j];
}else if(j == 'style'){ //Style is special
node.style.cssText = arguments[i][j];
}else if(typeof arguments[i][j] == 'function'){ //Basic event handlers
newNode.addEventHandler(node, j, arguments[i][j]);
}else{
node.setAttribute(j,arguments[i][j]); //Normal attributes
}
}
}
}
}
node.addEventHandler =
function(eventName, handler)
{ newNode.addEventHandler(this, eventName, handler); };
return node;
}
newNode.addEventHandler = function(node, eventName, handler)
{
try{ node.addEventListener(eventName,handler,false); //W3C
}catch(e){try{ node.attachEvent('on'+eventName,handler,"Language"); //MSIE
}catch(e){ node['on'+eventName]=handler; }} //Legacy
};
importScriptURI('http://en.wiktionary.org/w/index.php?title=User:Yair rand/addcomment.js&action=raw&ctype=text/javascript');
