在JavaScript中,有三種常用的綁定事件的方法
第一種辦法
函數寫在結構層裡面
非常不好,使頁面很混亂,行為與結構得不到分離
<input type="button" onclick="func();">
綁定事件的第二種辦法
好處:行為與結構開始分離
缺點:
第二種綁定方式中只能給一個時間綁定一個處理函數
即.onclick = fn1;
. onclick = fn2
最終的效果是onclick = fn2
<select name="xueli" > <option value="">請選擇學歷</option> <option value="大學" >大學</option> <option value="中學">中學</option> <option value="初中">初中</option> <option value="小學">小學</option> </select> <form action=""> <p>Email:<input type="text" name="email"> 姓名:<input type="text" name="ming" > </p> </form>
document.getElementsByTagName('select')[0].onclick= function (){ alert('嘻嘻'); } document.getElementsByName('email')[0].onblur=function (){ alert('哈哈哈'); }
window.onload = function(){ var d = document.getElementById('school'); function fn1(){ alert('hello'); } function fn2(){ alert('world'); } d.onclick = fn1;//賦值操作 最終顯示fn2 d.onclick = fn2; }
綁定事件的第三種辦法
//錯誤寫法1 window.onload = function(){ var d = document.getElementById('school'); function fn1(){//this此時指向window this.style.background = 'blue'; } function fn2(){//this此時指向window this.style.background = 'red'; } //寫一個匿名函數 //最終的出現錯誤 d.onclick = function (){ fn1(); fn2(); //fn1 fn2是屬性window的 實際上是這樣 window.fn1() window.fn2() } }
下面這種寫法沒有問題 但是給DOM樹額外增加了兩個變量
window.onload = function(){ var d = document.getElementById('school'); d.fn1 = function (){//fn1是d的屬性 最終this此時指向DOM對象 this.style.background = 'blue'; } d.fn2 = function (){//this此時指向DOM對象 this.style.background = 'red'; } //匿名函數 調用上面兩個函數 d.onclick = function (){ this.fn1(); this.fn2(); } }
不在使用onclick
window.onload = function(){ var d = document.getElementById('school'); //達到了一次綁定兩個函數 d.addEventListener('click',function () {alert('blue');this.style.background ='blue'}); d.addEventListener('click',function () {alert('red');this.style.background ='red'}); }
去除綁定 不能用匿名函數 匿名函數 當時產生 當時消失
var fn1 = function () {alert('blue');this.style.background ='blue'}; var fn2 = function () {alert('red');this.style.background ='red'}; function adde(){ var d = document.getElementById('school'); d.addEventListener('click',fn1); d.addEventListener('click',fn2); } function reme(){ var d = document.getElementById('school'); //d.removeEventListener('click',fn1);//只剩fn1 d.removeEventListener('click',fn2); }
在IE下第三種綁定事件的方法
<div id="school"> </div> <input type="button" value="加事件" onclick="adde();"> <input type="button" value="減事件" onclick="reme();">
var fn1 = function () {alert('blue');this.style.background ='blue'}; var fn2 = function () {alert('red');this.style.background ='red'}; function adde(){ var d = document.getElementById('school'); // IE6,7是後綁定的事件先發生 d.attachEvent('onclick',fn1); d.attachEvent('onclick',fn2); //fn2先發生 } function reme(){ var d = document.getElementById('school'); //d.deltachEvent('click',fn1);//只剩fn1 d.deltachEvent('click',fn2); }
總結
以上就是JavaScript中綁定事件與去除綁定的三種方式,希望本文的內容對大家學習或者使用Javascript能有所幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。