事件处理程序的执行上下文

以下五种方式添加事件

<!doctype html>
<html>
    <head>
        <title>事件处理程序的执行上下文</title>
        <meta charset="utf-8">
        <style>
        	div {
        		background: gold;
        		margin: 10px;
        	}
        </style>
    </head>
    <body>
    	<!-- 内联事件代码 -->
    	<div id="d1" onclick="alert(this.tagName)">DIV1</div>
    	<!-- 内联一个函数 -->
    	<div id="d2" onclick="fn()">DIV2</div>
    	<!-- DOM 0 -->
    	<div id="d3">DIV3</div>
    	<!-- DOM 2 -->
    	<div id="d4">DIV4</div>
    	<!-- IE低版本 -->
    	<div id="d5">DIV5</div>
    	
    	<script>
    		function $(id) {return document.getElementById(id)}
			var d1 = $('d1'), d2 = $('d2'), d3 = $('d3'), d4 = $('d4'), d5 = $('d5')
			
			// 事件处理程序
    		function fn() {
    			if (this.tagName) {
    				alert(this.tagName)
    			} else {
    				alert(this)
    			}
    		}
    		
    		// DOM 0 (All Browsers)
    		d3.onclick = fn
			
    		// DOM 2 (IE9/10, FF, Safari, Chrome, Opera)
    		try {
    			d4.addEventListener('click', fn, false)
    		} catch(e) {}
			
			// 低版本IE (IE6/7/8, Opera)
			try {
				d5.attachEvent('onclick', fn)
			}catch(e){}
			
    	</script>
    </body>
</html>

结果如下:

  1. 内联HTML (element)
  2. 内联HTML fn (window)
  3. DOM-0级onXXX (element)
  4. DOM-2级addEventListener (element)
  5. IE低版本attachEvent (IE6/7/8: window, Opera: element)
原文地址:https://www.cnblogs.com/snandy/p/2679103.html