Difference between revisions of "User:Waldir/vector.js"

Explain xkcd: It's 'cause you're dumb.
Jump to: navigation, search
(10 intermediate revisions by the same user not shown)
Line 1: Line 1:
mw.loader.load( '//commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-HotCat.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');