Difference between revisions of "User:Waldir/vector.js"
(update meta script: vector.js --> global.js) |
|||
Line 1: | Line 1: | ||
− | importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/ | + | importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/global.js&action=raw&ctype=text/javascript'); |
/** | /** |
Revision as of 10:42, 8 August 2017
importScriptURI('http://meta.wikimedia.org/w/index.php?title=User:Waldir/global.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');