js事件委托和事件代理案例分享
什么是事件委托/事件代理
利用事件的冒泡傳播機制(觸發(fā)當(dāng)前元素的某一個行為,它父級所有元素的相關(guān)行為都會被觸發(fā)),如果一個容器中有很多元素都要綁定點擊事件,我們沒有必要一個個的綁定了,只需要給最外層容器綁定一個點擊事件即可,在這個方法執(zhí)行的時候,通過事件源的區(qū)分來進行不同的操作。
具體小案例如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> *{ margin:0; padding:0; font-size:14px; } html,body{ width:100%; height:100%; overflow:hidden; } #box{ position:absolute; left:50%; top:50px; width:100px; height:30px; margin-left:-50px; line-height:30px; text-align:center; border:1px solid #2489cc; } #mark{ position:absolute; top:30px; left:-1px; width:300px; height:100px; line-height:100px; text-align:center; background:#ffe470; border:1px solid #2489cc; } </style> </head> <body> <div id='box'> <span>購物車</span> <div id="mark" style='display:none'> 查看購物車的詳細(xì)信息 </div> </div> <script> var mark = document.getElementById('mark'); document.body.onclick = function(e){ e = e || window.event; e.target = e.target || e.srcElement; //如果點擊的是box或者是#box下的span,我們判斷mark是否顯示,顯示讓其隱藏,反之讓其顯示 if(e.target.id==="box" || (e.target.tagName.toLowerCase()==="span" && e.target.parentNode.id==='box')){ if(mark.style.display === "none"){ mark.style.display === "block" }else{ mark.style.display === "none" } return; } //如果事件源是#mark,不進行任何的操作 if(e.target.id==="mark"){ return; } mark.style.display === "none" } </script> </body> </html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何在父窗口中得知window.open()出的子窗口關(guān)閉事件
在父窗口中得知window.open()出的子窗口關(guān)閉事件的方法有很多,在本文將為大家詳細(xì)介紹下,感興趣的朋友可以參考下2013-10-10JavaScript實現(xiàn)生成動態(tài)表格和動態(tài)效果的方法詳解
這篇文章主要介紹了如何通過JavaScript語言實現(xiàn)動圖表格的生成以及動態(tài)效果的實現(xiàn),文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-02-02Layui實現(xiàn)數(shù)據(jù)表格中鼠標(biāo)懸浮圖片放大效果,離開時恢復(fù)原圖的方法
今天小編就為大家分享一篇Layui實現(xiàn)數(shù)據(jù)表格中鼠標(biāo)懸浮圖片放大效果,離開時恢復(fù)原圖的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript語句錯誤throw、try及catch實例解析
這篇文章主要介紹了JavaScript語句錯誤throw、try及catch實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08也說JavaScript中String類的replace函數(shù)
最近讀了sharpxiajun的博文《javascript筆記--String類replace函數(shù)的一些事》,感覺寫的很好,很有幫助。2011-09-09