js 委托事件的实现
测试代码
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实现:
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。