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

以下五种方式添加事件

<!doctype html>
<html>
    <head>
        <title>事件处理程序的执行上下文</title>
        <meta charset="utf-8">
        <style>
        	div {
        		background: gold;
        		margin: 10px;
        	}
        </style>
    </head>
    <body>
    	<!-- 内联事件代码 -->
    	<div id="d1" οnclick="alert(this.tagName)">DIV1</div>
    	<!-- 内联一个函数 -->
    	<div id="d2" οnclick="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)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值