淺談addEventListener和on的區(qū)別

有的時(shí)候我會(huì)遇到導(dǎo)入本地文件<input class="IamInputElement" type="file"/>的情況怀浆,但是往往為了美觀或者為了可以自己設(shè)計(jì)一個(gè)美觀的樣式而將input的樣式設(shè)置為display:none。然后給出一個(gè)button戈鲁,為button添加click時(shí)間芥永,然后document.getElementByClassName("IamInputElement").click(),這樣就可以實(shí)現(xiàn)對(duì)input框的點(diǎn)擊了瞬内。

但是我們還需要獲取到input輸入的地址,這個(gè)時(shí)候往往會(huì)給input框添加上addEventListener事件:document.getXXX("XXX").addEventListener("change",function(e){

?var file ? = e.target.files[0]

})

另外如果是react的話就可以用this.refs.XXX.addEventListener來(lái)實(shí)現(xiàn)(一般會(huì)在componentDidMount中實(shí)現(xiàn))


以上作為一個(gè)分割線吧限书,雖然跟題目沒有什么太大的關(guān)系虫蝶。但是因?yàn)樯厦娴膯?wèn)題而引起的對(duì)題目(addEventListener和on的區(qū)別)的思考。家長(zhǎng)里短的說(shuō)一下倦西。

拋開上面的例子能真。以一個(gè)button為例子,在js中為他加上click點(diǎn)擊事件的話可以使用扰柠。document.getElementById("thisIsButtonId").onclick = function(){

?//dosomething

}

通過(guò)以上的方法可以在button被點(diǎn)擊的時(shí)候做出響應(yīng)粉铐。

但是這種方法如果為同一個(gè)button添加多個(gè)響應(yīng)事件,只會(huì)執(zhí)行最后一個(gè)卤档,因?yàn)楹竺娴臅?huì)覆蓋前面的蝙泼。

然后來(lái)看看addEventListener()方法:

document.getElementById("thisIsButtonId").addEventListener(“click”,function(){

?//dosomething

}),這個(gè)樣子的話就可以實(shí)現(xiàn)跟上面一樣的效果了。只是如果通過(guò)這個(gè)方法為button添加多個(gè)方法的時(shí)候每一個(gè)方法都會(huì)執(zhí)行劝枣。

來(lái)看看某網(wǎng)站的文檔說(shuō)明:

這里面的bool型參數(shù)useCapture是控制執(zhí)行的順序的(useCapture默認(rèn)為FALSE)

上面大概的意思是如果兩個(gè)element都包含響應(yīng)事件的話汤踏,useCapture控制執(zhí)行的順序:

如果useCapture為false:根據(jù)事件冒泡的順序執(zhí)行的。也就是說(shuō)是根據(jù)被點(diǎn)擊的元素向外逐個(gè)執(zhí)行舔腾。

如果useCaptrue為true:跟上面相反溪胶。也叫事件捕獲執(zhí)行。


為什么使用addEventListener()呢稳诚?

第一:允許為一個(gè)event(例如:click)添加多個(gè)handler哗脖。

第二:為我們提供了可選的執(zhí)行順序,有useCaptrue來(lái)控制(如果我沒有理解錯(cuò)的話)

第三:實(shí)用在任何DOM中采桃,這個(gè)在最前面提到的react中使用到了懒熙∏鹚穑可以通過(guò)this.refs.XXX.addeventListener('click',function(){},false)

另外普办,addEventListener()過(guò)后需要removeEventListener()的話需要使用同一個(gè)function()也就是說(shuō)document.getElementById("XX").addEventListener('click',function(){})

然后document.getElementById("XX").removeEventListener('click',function(){}),這樣是不對(duì)的。因?yàn)榍昂髢蓚€(gè)的function是不一樣的徘钥,即使他們的方法都是一模一樣的衔蹲。應(yīng)該使用

function func(){//dosomething},然后將這個(gè)func放進(jìn)去,這樣的話兩個(gè)方法用的就是同一個(gè)function了舆驶。但是要注意:func后面就不可以加“()”了


以前的時(shí)候很少看文檔橱健,現(xiàn)在慢慢養(yǎng)成這樣的習(xí)慣吧。這次總結(jié)(如果這鬼東西也能叫總結(jié)的話)沙廉,我看英文文檔看的心好累拘荡。最后的時(shí)候感覺自己總結(jié)的狗屁不通。慢慢改進(jìn)吧撬陵。x

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末珊皿,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子巨税,更是在濱河造成了極大的恐慌蟋定,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件草添,死亡現(xiàn)場(chǎng)離奇詭異驶兜,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)远寸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門抄淑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人驰后,你說(shuō)我怎么就攤上這事蝇狼。” “怎么了倡怎?”我有些...
    開封第一講書人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵迅耘,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我监署,道長(zhǎng)颤专,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任钠乏,我火速辦了婚禮栖秕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘晓避。我一直安慰自己簇捍,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開白布俏拱。 她就那樣靜靜地躺著暑塑,像睡著了一般。 火紅的嫁衣襯著肌膚如雪锅必。 梳的紋絲不亂的頭發(fā)上事格,一...
    開封第一講書人閱讀 51,598評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼驹愚。 笑死远搪,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的逢捺。 我是一名探鬼主播谁鳍,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼劫瞳!你這毒婦竟也來(lái)了棠耕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤柠新,失蹤者是張志新(化名)和其女友劉穎窍荧,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體恨憎,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蕊退,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了憔恳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓤荔。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖钥组,靈堂內(nèi)的尸體忽然破棺而出输硝,到底是詐尸還是另有隱情,我是刑警寧澤程梦,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布点把,位于F島的核電站,受9級(jí)特大地震影響屿附,放射性物質(zhì)發(fā)生泄漏郎逃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一挺份、第九天 我趴在偏房一處隱蔽的房頂上張望褒翰。 院中可真熱鬧,春花似錦匀泊、人聲如沸优训。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)揣非。三九已至,卻和暖如春伦吠,著一層夾襖步出監(jiān)牢的瞬間妆兑,已是汗流浹背魂拦。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工毛仪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搁嗓,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓箱靴,卻偏偏與公主長(zhǎng)得像腺逛,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子衡怀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 事件綁定的方式 給 DOM 元素綁定事件分為兩大類:在 html 中直接綁定 和 在 JavaScript 中綁定...
    Bruce_zhuan閱讀 1,036評(píng)論 0 6
  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品棍矛,去做同樣的事情,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式抛杨。簡(jiǎn)單...
    舟漁行舟閱讀 7,763評(píng)論 2 17
  • 我們首先要明白够委,我們給頁(yè)面添加效果用到的js到底是什么?js其實(shí)包含三部分:dom 文檔對(duì)象模型 bom 瀏覽...
    一直以來(lái)都很好閱讀 807評(píng)論 0 0
  • 上一篇文章介紹了問(wèn)題發(fā)生時(shí)怖现,人們常犯的三種錯(cuò)誤: 1. 掉入“否定狀況”的陷阱2. 在錯(cuò)誤的時(shí)間追究責(zé)任3. 對(duì)狀...
    唐T唐X閱讀 575評(píng)論 0 1
  • 昨夜茁帽,我無(wú)意中在網(wǎng)上搜尋自己十多年前寫的舊作,在當(dāng)年極為活躍的一個(gè)海外文學(xué)論壇上屈嗤,后來(lái)隨意點(diǎn)入一個(gè)標(biāo)題潘拨,卻看見壇主...
    歸來(lái)的金凝閱讀 867評(píng)論 2 5