nodelist.html revision 10d67463820db9c4acc3bc438d9e11a9dc72c9c5
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<html>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<head>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<title>FIXME</title>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/yui/yui.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/event-custom/event-custom.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/event-simulate/event-simulate.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/event/event.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/oop/oop.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/base/base.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/attribute/attribute.js"></script>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney<script type="text/javascript" src="/build/dom/dom-debug.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript" src="/build/node/node-debug.js"></script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<style type="text/css">
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney</style>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney</head>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<body>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney<div id="demo">
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney <p>lorem</p>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney <p title="ipsum">ipsum</p>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney <p>dolor</p>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney <p>sit</p>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney</div>
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney<script type="text/javascript">
b45cf0c43257bd3781496320d9602fac76d997f2Matt SweeneyYUI().use('*', function(Y) {
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney var a = ['foo', 'bar', 'baz:', 'fool'],
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney b = ['foo', 'baz', 'boo', 'bool'];
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney nodelist = Y.all('p');
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney //nodelist.set('style.color', 'red');
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney node = Y.get('p[title]');
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney/*
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney1. set title on all nodes
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney store initial value === prevVal
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney2. provide prevVal array in handler
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney3. fire node titleChange
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney4. fire nodelist titleChange
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney*/
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney node.on('innerHTMLChange', function(e) {
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney e.preventDefault();
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney e.newVal = 'hijacked val';
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney this._defAttrChangeFn(e);
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney console.log('Node: ' + e.type + ': ' + e.target._yuid);
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney });
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney //node.set('innerHTML', 'new content from Node');
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney node.after('innerHTMLChange', function(e) {
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney console.log('Node: afterInnerHTMLChange');
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney });
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney nodelist.on('innerHTMLChange', function(e) {
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney //console.log('NodeList: ' + e.type + ': ' + e.target);
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney });
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney var onClick = function(e) {
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney //e.preventDefault();
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney console.log('node click');
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney };
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney nodelist.on('click', onClick);
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney Y.get('#demo').addNode('<p>injected content</p>');
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney nodelist.on('refresh', function(e) {
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney e.added.on('click', onClick);
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney });
10d67463820db9c4acc3bc438d9e11a9dc72c9c5Matt Sweeney nodelist.refresh();
d2bacf915570731779738821c6d7b01b7d9600feMatt Sweeney nodelist.set('innerHTML', 'new content from NodeList');
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney //console.log(nodelist.get('title'));
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney});
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney</script>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney</body>
b45cf0c43257bd3781496320d9602fac76d997f2Matt Sweeney</html>