node.html revision 483a7d3cd8781164216ea128c254ad9a942cc603
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<link type="text/css" rel="stylesheet" href="/yui2/build/logger/assets/logger.css">
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<link type="text/css" rel="stylesheet" href="/yui2/build/yuitest/assets/testlogger.css">
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/yui/yui.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/event-custom/event-custom.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/event-simulate/event-simulate.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/event/event.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/oop/oop.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/dom/dom.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/build/node/node-debug.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/yui2/build/yahoo/yahoo-min.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/yui2/build/dom/dom-min.js"></script>
2dd75eff92ef66e22cca286b6f4fe5a9c929af9dPhill Cunnington<script type="text/javascript" src="/yui2/build/event/event.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/yui2/build/logger/logger-min.js"></script>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan<script type="text/javascript" src="/yui2/build/yuitest/yuitest.js"></script>
45e9f4e13faca91c1a0f87ef805933e155cf3ae6Dirk Hogan width:1000px;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan min-height:200px;
2dd75eff92ef66e22cca286b6f4fe5a9c929af9dPhill Cunnington background:#ccc;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan font-size:10px;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan height:10em;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan padding:15px 0;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan width:200px;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan background:#ccc;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan position:absolute;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan overflow:hidden;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan background:green;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan position:absolute;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan height:10px;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan#test-computed {
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan margin:auto;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan padding:10px;
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <form id="test-form" class="test-class" action="#">
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <div id="test-prop">text<em id="test-contains">test<span></span></em><strong>node</strong></div>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <div id="set-style"><div class="bar" id="bar">setStyle</div>foo<div>blah</div></div>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <div id="test-children">foo <span>bar</span> <strong>baz</strong> </div>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <div id="inline-style" style="color: green">inline style</div>
3744900be632496920d4c9aca8f94ba6db4dd882Dirk Hogan <div id="test-computed">test computed style</div>
YUI({ base: '/build/', filter: 'debug' }).use('node', function(Y) {
var tool = YAHOO.tool,
var Assert = YAHOO.util.Assert;
var ArrayAssert = YAHOO.util.ArrayAssert;
e.currentTarget.detach('click', handleClick);
Y.Node.get('html').on('click', handleClick);
return document.getElementById(id);
var $ = Y.Selector.query;
name: 'Y.Node Instance',
var node = Y.get('#test-nodes'),
nodes = Y.all('#test-nodes *');
Assert.areEqual(byId('test-nodes'), Y.Node[Y.get('#test-nodes')._yuid]()[0], 'Y.get("#test-nodes")');
Assert.areEqual(byId('test-nodes'), Y.Node[Y.get('#test-nodes')._yuid]()[0], 'Y.get("#test-nodes")');
Assert.areEqual(byId('test-nodes').getElementsByTagName('li')[0],
Assert.areEqual(byId('test-nodes').getElementsByTagName('li')[1],
ArrayAssert.itemsAreEqual($('#test-select option'), Y.Node[Y.all('#test-select option')._yuid](), 'Y.get("#test-select option")');
Assert.areEqual(nodes.size(), Y.all('#test-nodes *').size(), 'nodes.size() === Y.all("#test-nodes").size()');
nodes = Y.all('#test-nodes *'),
nodes.each(function(node, i, list) {
console.log(i);
Assert.areEqual(nodes, instance, 'nodes === instance');
node = Y.get('#' + id),
nodes = Y.all('#' + id + ' *');
Assert.areEqual(element.firstChild.nextSibling.nodeName, node.get('firstChild').get('nextSibling').get('nodeName'), 'node.firstChild.nextSibling.nodeName"');
Assert.areEqual(element.lastChild.nodeName, node.get('lastChild').get('nodeName'), 'lastChild.nodeName"');
Assert.areEqual(element.lastChild.nodeName, node.get('lastChild.nodeName'), 'node.get("lastChild.nodeName")');
Assert.areEqual(element.lastChild.previousSibling.nodeName, node.get('lastChild').get('previousSibling').get('nodeName'), 'node.lastChild.previousSibling.nodeName');
Assert.areEqual('test-nodes', nodes.get('parentNode')[0].get('id'), 'nodes.get(parentNode)[0].get("id") === test-nodes');
Assert.areEqual(element.firstChild.nodeType, node.get('firstChild').get('nodeType'), 'firstChild.get("nodeType")');
Assert.areEqual(element.offsetParent.tagName, node.get('offsetParent').get('tagName'), 'offsetParent.tagName === offsetParent.tagName');
Assert.areEqual('item 1', Y.Lang.trim(nodes.get('children')[0].get('text')[0]), 'nodes.get("children")[0].get("text")[0]');
ArrayAssert.itemsAreEqual($('#test-select option'),
Assert.areEqual(byId('test-nodes').childNodes.length, node.get('childNodes').get('tagName').length, 'node.get("childNodes")');
ArrayAssert.itemsAreEqual(byId('test-nodes').childNodes.length, node.get('childNodes').get('length').length, "node.get('childNodes').get('length')");
node = Y.get('#' + id);
Assert.areEqual('fresh', node.create('<div id="fresh">fresh</div>').get('id'), 'node.create from string)');
node = Y.get('#' + id),
nodes = Y.all('#test-nodes *');
var childNodes = Y.get('body').get('childNodes');
childNodes.set('title', 'foo bar');
Assert.isTrue(byId('test-nodes').title == 'foo bar', 'Y.get("body").get("childNodes").set("title")');
node.set('foo', 'foo');
node.set('title', 'my title');
nodes.set('className', 'foo');
Assert.areEqual(2, byId('test-select').selectedIndex,
var node = Y.Node.get('#test-prop');
Assert.areEqual(element.getElementsByTagName('em')[0].nodeName, node.getElementsByTagName('em').item(0).get('nodeName'), 'getElementsByTagName');
var insertNode = document.createElement('div');
Y.stamp(insertNode);
insertNode.innerHTML = 'inserted node';
Assert.isTrue(Y.get('body').get('lastChild').compareTo(Y.get('#test-append')), 'get("body").appendChild(Y.get("#test-append"))');
Assert.areEqual(byId('test-append'), Y.Node[Y.get('body').get('lastChild')._yuid]()[0], 'get("body").appendChild(Y.get([0]"#test-append"))');
Assert.areEqual('inserted node', node.appendChild(insertNode).get('innerHTML'), 'appendChild(element input)');
Assert.areEqual('inserted node', node.removeChild(insertNode).get('innerHTML'), 'removeChild(element input)');
Assert.areEqual('inserted node', node.appendChild(Y.get(insertNode)).get('innerHTML'), 'appendChild(Node input)');
Assert.areEqual('inserted node', node.removeChild(Y.get(insertNode)).get('innerHTML'), 'removeChild(Node input)');
Assert.isTrue(node.get('childNodes').size() === node.cloneNode(true).get('childNodes').size(), 'node.get("childNodes").size() === node.cloneNode(true).get("childNodes").size()');
Assert.isFalse(node.contains(document.getElementsByTagName('div')), 'contains() false positive for collection');
return el.get('id') === 'doc';
return el.hasAttribute('foo');
Assert.areEqual(byId('test-contains'), Y.Node[node.getById('test-contains')._yuid]()[0], 'node.getById("test-contains")');
node.removeAttribute('title');
var frag = Y.get('document').invoke('createDocumentFragment'),
frag.appendChild(element);
Y.get('body').appendChild(frag);
var node = Y.Node.get(element);
Assert.areEqual(document.documentElement.scrollLeft, newNode.get('docScrollX'), 'newNode.get("docScrollX")');
Assert.areEqual(document.documentElement.scrollTop, node.get('docScrollY'), 'node.get("docScrollY")');
node.setXY([100, 100]);
ArrayAssert.itemsAreEqual(Y.DOM.region(Y.DOM.byId('doc')), Y.Node.get('#doc').get('region'), 'node.get("region")');
var node = Y.Node.get(element);
Assert.isTrue(node.get('previousSibling').hasClass('test-class'), 'node.get("previousSibling").hasClass("test-class")');
node.addClass('foo');
node.removeClass('foo');
node.addClass('foo');
Y.Node.get('body').get('childNodes').addClass('foo');
node.replaceClass('foo', 'bar');
node = Y.Node.get(element),
nodes = node.get('childNodes');
node.setStyle('width', '20em');
node.setStyle('marginTop', '1em');
node.setStyle('opacity', 0.5);
node.setStyle('float', 'left');
node.setStyle('float', 'left');
nodes.setStyle('marginTop', '1em');
var node = Y.Node.get('#get-style');
node.setStyle('opacity', 0.5);
node.setStyle('visibility', 'hidden');
node.setStyle('visibility', 'visible');
var node = Y.get('#test-computed');
domNode.style.zoom = 1;
domNode.style.border = 'medium solid #000';
var bw = (Y.UA.ie) ? 4 : 3;
var h = node.get('offsetHeight') - 20 - 2 * bw;
Assert.areEqual(h, Math.round(parseFloat(node.getComputedStyle('height'))), "height: auto (offset minus padding and border)");
domNode.style.padding = '1em';
domNode.style.margin = 'auto';
domNode.parentNode.style.visibility = 'hidden';
domNode.parentNode.style.visibility = 'visible';
var element = Y.Node.get(node);
var node = Y.Node.get(element, null, true);
Assert.isTrue(node.get('firstChild').compareTo(node.firstChild), "node.firstChild() (is textNode)");
node = Y.get('#' + id),
nodes = Y.all('#test-nodes *');
var win = Y.get(window);
//Assert.areEqual(window, Y.Node[Y.get('document').get('defaultView')._yuid]()[0], 'win.get(document)');
var mask = document.createElement('div');
mask.className = 'mask';
document.body.appendChild(mask);
var doc = Y.Node.get('document');
Y.DOM.setStyle(mask, 'opacity', 0.4);
Assert.areEqual(document.documentElement.scrollLeft, doc.get('docScrollX'), 'doc.get("docScrollX")');
Assert.areEqual(document.documentElement.scrollTop, doc.get('docScrollY'), 'doc.get("docScrollY")');
name: 'Instance Y.NodeExtras',
var element = Y.Node.get('#test-extras');
tool.TestRunner.add(suite);