MediaWiki:Gadget-LegacyScriptsNewNode.js
Nota: dopo aver pubblicato, potrebbe essere necessario pulire la cache del proprio browser per vedere i cambiamenti.
- Firefox / Safari: tieni premuto il tasto delle maiuscole Shift e fai clic su Ricarica, oppure premi Ctrl-F5 o Ctrl-R (⌘-R su Mac)
- Google Chrome: premi Ctrl-Shift-R (⌘-Shift-R su un Mac)
- Edge: tieni premuto il tasto Ctrl e fai clic su Aggiorna, oppure premi Ctrl-F5.
//this script is deprecated do not use newNode function! use jQuery instead
/**
* 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.
**/
var newNode = window.newNode = 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
};