DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript中綁定事件的三種方式及去除綁定
JavaScript中綁定事件的三種方式及去除綁定
編輯:關於JavaScript     

在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能有所幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved