测试代码
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50 |
function init() { var d = document.getElementById("test"); d.appendChild(createUl()); console.profile("f1"); f1(); console.profileEnd("f1"); console.profile("f2"); f2(d); console.profileEnd("f2"); } //普通方式注册事件 function f1() { var ul = document.getElementById("testUl"); for (var i = 0; i < ul.childNodes.length; i++) { ul.childNodes[i].onclick = click; } } //事件委托 function f2(d) { d.onclick = function(e) { var e = e || window.event; var target = e.srcElement || e.target; if (target.tagName == "LI") { alert(target.innerHTML); } } } function click() { alert("1"); } function createUl() { var ul = document.createElement("UL"); ul.id = "testUl"; var lis = ""; for (var i = 0; i < 200; i++) { lis += "<li>" + i + "</li>"; } ul.innerHTML = lis; return ul; } |
测试结果:使用事件委托方式性能要高的多

1、jquery实现:
原文:http://www.cnblogs.com/hongwei8455/p/3678321.html