JavaScript 阻止事件默認(rèn)行為的幾種方法
默認(rèn)行為
在JavaScript中,事件默認(rèn)行為是指在特定的事件發(fā)生時(shí)瀏覽器自動(dòng)執(zhí)行的操作。例如,當(dāng)用戶單擊一個(gè)鏈接時(shí),瀏覽器會(huì)自動(dòng)跳轉(zhuǎn)到鏈接的URL頁面;form 元素 的 action 屬性值表單內(nèi)容要提交的地址,而用戶點(diǎn)擊表單元素中嵌套的提交按鈕時(shí),就會(huì)有一個(gè)默認(rèn)的提交操作。
而有時(shí)候,不需要這些默認(rèn)行為。比如,我們提交表單希望ajax 異步發(fā)送到服務(wù)器,不需要form 的默認(rèn)事件提交跳轉(zhuǎn)行為。
一句話說就是 html 元素自帶的行為。
阻止默認(rèn)行為
1. 使用event.preventDefault()方法:
這是阻止事件默認(rèn)行為最常用的方法之一。當(dāng)事件被觸發(fā)時(shí),可以調(diào)用event.preventDefault()方法來阻止瀏覽器執(zhí)行其默認(rèn)行為。例如,在單擊鏈接時(shí),可以通過以下方式阻止瀏覽器跳轉(zhuǎn)到鏈接的URL頁面:
document.querySelector('a').addEventListener('click', function(event) { event.preventDefault(); });
2. 使用return false:
在某些情況下,可以在事件處理程序中使用return false來阻止事件默認(rèn)行為。這種方式通常用于內(nèi)聯(lián)事件處理程序,例如onclick屬性。例如,以下代碼將阻止單擊鏈接時(shí)的默認(rèn)行為:
注意:如果寫在 jQuery 中,能夠同時(shí)阻止默認(rèn)行為和阻止冒泡。
<a href="#" rel="external nofollow" onclick="return false;">點(diǎn)擊我不會(huì)跳轉(zhuǎn)</a>
3. 使用event.returnValue屬性:
在舊版本的IE瀏覽器中,可以使用event.returnValue屬性來阻止事件默認(rèn)行為(現(xiàn)在很多瀏覽器也支持)。將event.returnValue設(shè)置為false可以阻止默認(rèn)行為的執(zhí)行。例如:
document.querySelector('a').attachEvent('onclick', function(event) { event.returnValue = false; });
4. 使用event.stopPropagation()方法(僅阻止事件傳播):
阻止事件傳播。 event.stopPropagation()方法用于阻止事件的進(jìn)一步傳播,而不是直接阻止事件的默認(rèn)行為。它可以用于停止事件冒泡到父元素或其他事件監(jiān)聽器。例如:
document.querySelector('.child').addEventListener('click', function(event) { event.stopPropagation(); });
5. 使用 cancelable 屬性
查看狀態(tài)。 該屬性表示事件是否可以取消,返回一個(gè)布爾值。該屬性是只讀屬性。true 表示可以取消。
<a id="test" rel="external nofollow" rel="external nofollow" >百度</a> <script> let test = document.getElementById('test'); test.onclick = function (e) { // 可以取消事件的默認(rèn)行為 console.log(e.cancelable) } </script>
6. defaultPrevented 方法
查看狀態(tài)。 也是 event的一個(gè)屬性,表示默認(rèn)行為是否被阻止,true 表示被阻止。
<a id="test" rel="external nofollow" rel="external nofollow" >百度</a> <script> let test = document.getElementById('test'); test.onclick = function (e) { e.preventDefault() console.log(e.defaultPrevented) // true } </script>
需要注意的是,不同的事件有不同的默認(rèn)行為,因此阻止默認(rèn)行為的方法可能會(huì)有所不同。一些常見的事件默認(rèn)行為包括表單提交、鏈接點(diǎn)擊、表單元素的鍵盤輸入等。
總結(jié)起來,使用event.preventDefault()方法是最常見和推薦的阻止事件默認(rèn)行為的方法。其他方法如return false和event.returnValue屬性在特定情況下可能有用,但不如event.preventDefault()方法靈活和通用。另外,event.stopPropagation()方法用于阻止事件傳播,而不是直接阻止事件的默認(rèn)行為。
到此這篇關(guān)于JavaScript 阻止事件默認(rèn)行為的幾種方法的文章就介紹到這了,更多相關(guān)JavaScript 阻止默認(rèn)行為內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript實(shí)現(xiàn)模塊拖拽功能的代碼示例
這篇文章將給大家詳細(xì)介紹一下JavaScript實(shí)現(xiàn)模塊的拖拽功能的代碼示例,文中有詳細(xì)的實(shí)現(xiàn)步驟,需要的朋友可以參考下2023-07-07原生js實(shí)現(xiàn)淘寶首頁點(diǎn)擊按鈕緩慢回到頂部效果
本例將實(shí)現(xiàn)這樣的一個(gè)效果:下拉到一定距離后按鈕才顯示出來,鼠標(biāo)放到按鈕上時(shí),按鈕背景會(huì)變成灰色,并且圖標(biāo)變成了文字。點(diǎn)擊按鈕緩慢回到頂部2014-04-04一文學(xué)習(xí)JavaScript?使用誤區(qū)
在?JavaScript?程序中如果你在?if?條件語句中使用賦值運(yùn)算符的等號(hào)?(=)?將會(huì)產(chǎn)生一個(gè)錯(cuò)誤結(jié)果,?正確的方法是使用比較運(yùn)算符的兩個(gè)等號(hào)?(==),這篇文章主要介紹了一文學(xué)習(xí)JavaScript?使用誤區(qū),需要的朋友可以參考下2023-02-02typescript返回值類型和參數(shù)類型的具體使用
本文主要介紹了typescript返回值類型和參數(shù)類型的具體使用文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06微信小程序scroll-view仿拼多多橫向滑動(dòng)滾動(dòng)條
這篇文章主要為大家詳細(xì)介紹了微信小程序scroll-view仿拼多多橫向滑動(dòng)滾動(dòng)條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07javascript 數(shù)組排序函數(shù)sort和reverse使用介紹
reverse方法將一個(gè)Array對(duì)象中的元素位置進(jìn)行反轉(zhuǎn),sort方法返回一個(gè)元素已經(jīng)進(jìn)行了排序的 Array 對(duì)象,下面為大家介紹下2013-11-11JS內(nèi)置對(duì)象和Math對(duì)象知識(shí)點(diǎn)詳解
在本篇文章里小編給大家分享的是關(guān)于JS內(nèi)置對(duì)象和Math對(duì)象知識(shí)點(diǎn)詳解內(nèi)容,有需要的朋友們可以參考下。2020-04-04Windows Live的@live.com域名注冊(cè)漏洞 利用代碼
Windows Live的@live.com域名注冊(cè)漏洞 利用代碼...2006-12-12