More work on micro DOM library.

This commit is contained in:
Jürg Lehni 2012-11-14 01:31:49 -08:00
parent c4a66cff0a
commit 9a180b5377

View file

@ -31,44 +31,47 @@ var DomElement = new function() {
function create(nodes, parent) { function create(nodes, parent) {
var res = []; var res = [];
for (var i = 0, l = nodes && nodes.length; i < l;) { for (var i = 0, l = nodes && nodes.length; i < l;) {
var tag = nodes[i++]; var el = nodes[i++];
if (typeof tag === 'string') { if (typeof el === 'string') {
var el = document.createElement(tag); el = document.createElement(el);
// Do we have attributes? } else if (!el || !el.nodeType) {
if (typeof nodes[i] === 'object' && !Array.isArray(nodes[i])) continue;
DomElement.set(el, nodes[i++]);
// Do we have children?
if (Array.isArray(nodes[i]))
create(nodes[i++], el);
// Are we adding to a parent?
if (parent)
parent.appendChild(el);
res.push(el);
} }
// Do we have attributes?
if (Base.isObject(nodes[i]))
DomElement.set(el, nodes[i++]);
// Do we have children?
if (Array.isArray(nodes[i]))
create(nodes[i++], el);
// Are we adding to a parent?
if (parent)
parent.appendChild(el);
res.push(el);
} }
return res; return res;
} }
return { return {
create: function(tag, attributes, children) { create: function(arg0, arg1) {
var res = create(arguments); var isArray = Array.isArray(arg0),
res = create(isArray ? arg0 : arguments, isArray ? arg1 : null);
return res.length == 1 ? res[0] : res; return res.length == 1 ? res[0] : res;
}, },
find: function(selector) { find: function(selector, root) {
return document.querySelector(selector); return (root || document).querySelector(selector);
}, },
findAll: function(selector) { findAll: function(selector, root) {
return document.querySelectorAll(selector); return (root || document).querySelectorAll(selector);
}, },
get: function(el, key) { get: function(el, key) {
return el return el
? special.test(key) ? special.test(key)
? key === 'value' ? key === 'value' || typeof el[key] !== 'string'
? el[key] ? el[key]
: typeof el[key] === 'string' : true
: key in translated : key in translated
? el[translated[key]] ? el[translated[key]]
: el.getAttribute(key) : el.getAttribute(key)
@ -76,6 +79,8 @@ var DomElement = new function() {
}, },
set: function(el, key, value) { set: function(el, key, value) {
if (!el)
return el;
if (typeof key !== 'string') { if (typeof key !== 'string') {
for (var name in key) for (var name in key)
if (key.hasOwnProperty(name)) if (key.hasOwnProperty(name))
@ -125,6 +130,11 @@ var DomElement = new function() {
new RegExp('\\s*' + cls + '\\s*'), ' ').trim(); new RegExp('\\s*' + cls + '\\s*'), ' ').trim();
}, },
removeChildren: function(el) {
while (el.firstChild)
el.removeChild(el.firstChild);
},
getBounds: function(el, viewport) { getBounds: function(el, viewport) {
var rect = el.getBoundingClientRect(), var rect = el.getBoundingClientRect(),
doc = el.ownerDocument, doc = el.ownerDocument,