JavaScript中綁定事件的三種方式及去除綁定
在JavaScript中,有三種常用的綁定事件的方法
第一種辦法
函數(shù)寫在結(jié)構(gòu)層里面
非常不好,使頁面很混亂,行為與結(jié)構(gòu)得不到分離
<input type="button" onclick="func();">
綁定事件的第二種辦法
好處:行為與結(jié)構(gòu)開始分離
缺點:
第二種綁定方式中只能給一個時間綁定一個處理函數(shù)
即.onclick = fn1; . onclick = fn2 最終的效果是onclick = fn2
<select name="xueli" > <option value="">請選擇學(xué)歷</option> <option value="大學(xué)" >大學(xué)</option> <option value="中學(xué)">中學(xué)</option> <option value="初中">初中</option> <option value="小學(xué)">小學(xué)</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';
}
//寫一個匿名函數(shù)
//最終的出現(xiàn)錯誤
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';
}
//匿名函數(shù) 調(diào)用上面兩個函數(shù)
d.onclick = function (){
this.fn1();
this.fn2();
}
}
不在使用onclick
window.onload = function(){
var d = document.getElementById('school');
//達(dá)到了一次綁定兩個函數(shù)
d.addEventListener('click',function () {alert('blue');this.style.background ='blue'});
d.addEventListener('click',function () {alert('red');this.style.background ='red'});
}
去除綁定 不能用匿名函數(shù) 匿名函數(shù) 當(dāng)時產(chǎn)生 當(dāng)時消失
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是后綁定的事件先發(fā)生
d.attachEvent('onclick',fn1);
d.attachEvent('onclick',fn2); //fn2先發(fā)生
}
function reme(){
var d = document.getElementById('school');
//d.deltachEvent('click',fn1);//只剩fn1
d.deltachEvent('click',fn2);
}
總結(jié)
以上就是JavaScript中綁定事件與去除綁定的三種方式,希望本文的內(nèi)容對大家學(xué)習(xí)或者使用Javascript能有所幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
JS判斷當(dāng)前是否平板安卓并是否支持cordova方法的示例代碼
這篇文章主要介紹了JS判斷當(dāng)前是否平板安卓并是否支持cordova方法,pc和安卓平板共用一套代碼,平板的代碼用了cordova做了一個殼子嵌套如果用了cordova就不支持elementUI中的上傳功能,本文通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
微信小程序 flexbox layout快速實現(xiàn)基本布局的解決方案
flexbox layout 彈性盒子布局。彈性盒子可以快速的對小程序進(jìn)行布局。這篇文章主要介紹了微信小程序 flexbox layout快速實現(xiàn)基本布局的方法,需要的朋友可以參考下2020-03-03
javascript感應(yīng)鼠標(biāo)圖片透明度顯示的方法
這篇文章主要介紹了javascript感應(yīng)鼠標(biāo)圖片透明度顯示的方法,涉及javascript針對鼠標(biāo)事件及圖片透明度操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02
jquery將標(biāo)簽元素的高設(shè)為屏幕的百分比
這篇文章主要介紹了js將標(biāo)簽元素的高設(shè)為屏幕的百分比,需要的朋友可以參考下2017-04-04
typeScript中數(shù)組類型定義及應(yīng)用詳解
相信大家應(yīng)該都知道ts只允許數(shù)組中包括一種數(shù)據(jù)類型的值,下面這篇文章主要給大家介紹了關(guān)于typeScript中數(shù)組類型定義及應(yīng)用的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05

