标签:ret highlight splay targe add document append apply exp
http://www.jb51.net/article/100809.htm
这篇博客非常的棒,
var addEvent = (function () { if (document.addEventListener) { return function (element, type, handler) { element.addEventListener(type, handler, false); }; } else if (document.attachEvent) { return function (element, type, handler) { element.attachEvent(‘on‘ + type, function () { handler.apply(element, arguments); }); }; } else { return function (element, type, handler) { element[‘on‘ + type] = function () { return handler.apply(element, arguments); }; }; } })(), getClassElements = function (parentElement, classname) { var all, element, classArr = [], classElements = []; if (parentElement.getElementsByClassName) { return parentElement.getElementsByClassName(classname); } else { all = parentElement.getElementsByTagName(‘*‘); for (var i = 0, len = all.length; i < len; i++) { element = all[i]; classArr = element && element.className && element.className.split(‘ ‘); if (classArr) { for (var j = 0; j < classArr.length; j++) { if (classArr[j] === classname) { classElements.push(element); } } } } return classElements; } }, delegate = function () { // 参数:element, type, [selector,] handler var args = arguments, element = args[0], type = args[1], handler; if (args.length === 3) { handler = args[2]; return addEvent(element, type, handler); } if (args.length === 4) { selector = args[2]; handler = args[3]; return addEvent(element, type, function (event) { var event = event || window.event, target = event.target || event.srcElement, quickExpr = /^(?:[a-zA-Z]*#([\w-]+)|(\w+)|[a-zA-Z]*\.([\w-]+))$/, match, idElement, elements, tagName, count = 0, len; if (typeof selector === ‘string‘) { match = quickExpr.exec(selector); if (match) { // #ID selector if (match[1]) { idElement = document.getElementById(match[1]); tagName = match[0].slice(0, match[0].indexOf(‘#‘)); // tag selector } else if (match[2]) { elements = element.getElementsByTagName(selector); // .class selector } else if (match[3]) { elements = getClassElements(element, match[3]); tagName = match[0].slice(0, match[0].indexOf(‘.‘)); } } if (idElement) { if ( tagName ? tagName === idElement.nodeName.toLowerCase() && target === idElement : target === idElement ) { return handler.apply(idElement, arguments); } } else if (elements) { for (len = elements.length; count < len; count++) { if ( tagName ? tagName === elements[count].nodeName.toLowerCase() && target === elements[count] : target === elements[count] ) { return handler.apply(elements[count], arguments); } } } } }); } };
测试代码:
<div class="animated bounceOut cc">this is our 未来!</div> <div class="haha" style="padding:50px;border:1px solid red;"> </div> <script type="text/javascript" src="./main.js"></script> <script> window.delegate($(‘.haha‘)[0], ‘mouseover‘, ‘.haha1‘, function(event) { alert("nihao"); }); $(‘.haha‘).append(‘<div class="haha1" style="display: inline-block;width: 500px;height: 300px;border:1px solid black;">this is hahaboy!</div>‘); </script>
但是作者还提供了一种,类似jquery的方法。
自己看吧,z真心感觉厉害
标签:ret highlight splay targe add document append apply exp
原文地址:http://www.cnblogs.com/coding4/p/6907891.html