JS事件在IE與FF中的區(qū)別詳細(xì)解析
之道的易搜項目中的搜索分類是通過JS動態(tài)生成的,每個生成的元素都要動態(tài)的添加屬性、事件。其中,添加屬性可以采用賦值的方式,這對IE和FF都是適用的。比如:
var element = document.createElement('select');
element.id = "myselect";
上面的語句在IE和FF中都會有同樣的效果,并且運行正常。但是我們創(chuàng)建的元素,大部分是要給其動態(tài)添加事件的,顯然,我們不能和添加屬性一樣,直接在后面打個dot,然后寫個事件名,然后后面跟著一串代碼,那樣是會報錯的。所以我們可以采用如下的方法來添加事件:
首先:我們要判斷當(dāng)前的瀏覽器是什么瀏覽器,我們?nèi)匀谎佑弥暗亩x,
if( element.attachEvent ){
//為IE以及IE內(nèi)核的瀏覽器(1)
}else if( element.addEventListener){
//為FF以及NS內(nèi)核的瀏覽器(2)
}
上面的if語句塊就是幫我們完成當(dāng)前瀏覽器是IE還是FF的判斷。
瀏覽器判斷出來,然后我們要做的就是把函數(shù)注冊到元素里面。下面我們給出我們定義的一個功能函數(shù):
function showElementId(elmt){
alert(elmt.id);
}
函數(shù)功能很簡單,就是提示出參數(shù)里面的元素的ID。
如果是IE瀏覽器,我們把如下代碼插入到上面的注釋(1)處:
element.attachEvent( "onclick",function(){showElementId(elmt)});
如果是FF瀏覽器,我們把如下代碼插入到上面的注釋(2)處:
var eventName = "onclick".replace(/on(.*)/i,'$1');
element.addEventListener( eventName,function(){showElementId(elmt)},false);
因為在FF中給元素注冊事件的時候,不需要事件名稱前面的“on”,所以要把on給替換掉。
好啦,如果今后各位同行在開發(fā)項目中,遇到要用JS動態(tài)給元素添加事件的時候,就可以采用上面的方法。那樣就可以避免用戶在用FF瀏覽器時候不能使用你幸苦開發(fā)的功能了。
相關(guān)文章
BootStrap selectpicker后臺動態(tài)綁定數(shù)據(jù)的方法
這篇文章主要為大家詳細(xì)介紹了BootStrap selectpicker后臺動態(tài)綁定數(shù)據(jù)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
thinkjs微信中控之微信鑒權(quán)登陸的實現(xiàn)代碼
這篇文章主要介紹了thinkjs微信中控之微信鑒權(quán)登陸的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
微信小程序數(shù)據(jù)監(jiān)聽器使用實例詳解
這篇文章主要介紹了微信小程序數(shù)據(jù)監(jiān)聽器使用實例,數(shù)據(jù)監(jiān)聽器用于監(jiān)聽和響應(yīng)任何屬性和數(shù)據(jù)字段的變化,從而執(zhí)行特定的操作。它的作用類似于vue中的watch偵聽器2023-04-04
整理關(guān)于Bootstrap導(dǎo)航的慕課筆記
這篇文章主要為大家整理了關(guān)于Bootstrap導(dǎo)航的慕課筆記,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03

