案例實操vue事件修飾符帶你快速了解與應(yīng)用
一.速識概念:
你好呀,最近過的怎么樣?今天總結(jié)了vue常見的事件修飾符,學(xué)習(xí)面試都是常遇到的,快來看看吧~??
先引用vue官網(wǎng)的話說----在事件處理程序中調(diào)用 event.preventDefault() 或 event.stopPropagation() 是非常常見的需求。盡管我們可以在方法中輕松實現(xiàn)這點,但更好的方式是:方法只有純粹的數(shù)據(jù)邏輯,而不是去處理 DOM 事件細節(jié)。為了解決這個問題,Vue.js 為 v-on 提供了事件修飾符。之前提過,修飾符是由點開頭的指令后綴來表示的。
簡單通俗來說就是,我想要實現(xiàn)一些功能的方法,但是我不想寫代碼,我想有直接封裝好的直接拿來用,所以vue就提供了所謂的事件修飾符,我們直接調(diào)用就可以達到想要的功能。
分類如下:
| 事件修飾符 | 功能作用 |
| .stop | 阻止冒泡 |
| .prevent | 阻止默認事件 |
| .capture | 捕獲冒泡 |
| .self | 綁定自身,自身才能觸發(fā) |
| .once | 事件只能觸發(fā)一次 |
| .passive | 對dom默認事件性能優(yōu)化 |
擴展:按鍵修飾符、系統(tǒng)修飾符
二.stop修飾符:
阻止冒泡,阻止事件向上級DOM元素傳遞。
什么是冒泡呢?以下面這個例子,比如有一個天藍色父盒子,里面包裹了一個綠色子盒子,分別綁定點擊事件將輸出不同內(nèi)容:
<div class="father" @click="father">
<div class="child" @click="child"></div>
</div>
.father {
width: 200px;
height: 200px;
background-color: skyblue;
}
.child {
width: 100px;
height: 100px;
background-color: green;
}
father() {
console.log("trigger father");
},
child() {
console.log("trigger child");
},
效果如下,可以發(fā)現(xiàn),當(dāng)點擊子盒子時,不僅子盒子事件被觸發(fā),連同父盒子的事件也被觸發(fā)了。而只點父盒子時,只有父盒子事件觸發(fā)。這就是冒泡,事件會向上級DOM元素傳遞,由內(nèi)而外,依次觸發(fā)。

當(dāng)使用 .stop 事件修飾符時就能很簡單的阻止冒泡了,用法如下,直接給子盒子的點擊事件后加上.stop即可:
<div class="child" @click.stop="child"></div>
效果如下:

二.prevent修飾符:
阻止默認事件觸發(fā)。默認事件指對DOM的操作會引起自動執(zhí)行的動作,比如點擊a標簽超鏈接的時候會進行默認進行頁面的跳轉(zhuǎn)等等。
如下,定義一個超鏈接:
<a >北極光之夜。</a>
正常情況,點擊后默認跳轉(zhuǎn):

添加prevent事件修飾符,取消默認的點擊跳轉(zhuǎn)頁面事件:
<a @click.prevent>北極光之夜。</a>
看,默認點擊跳轉(zhuǎn)頁面沒了:

三.capture修飾符:
捕獲冒泡,即當(dāng)冒泡發(fā)生時,有capture修飾符的dom元素會先執(zhí)行,如果有多個,從外到內(nèi)依次
執(zhí)行,最后再按自然冒泡順序執(zhí)行觸發(fā)的事件。
以下面這個例子,比如有一個天藍色父盒子,里面包裹了一個綠色子盒子,里面再包裹了一個橙色孫子盒子,分別綁定點擊事件將輸出不同內(nèi)容:
<div class="father" @click="father">
<div class="child" @click="child">
<div class="grandSon" @click="grandSon"></div>
</div>
.father {
width: 200px;
height: 200px;
background-color: skyblue;
}
.child {
width: 100px;
height: 100px;
background-color: green;
}
.grandSon {
width: 50px;
height: 50px;
background-color: orange;
}
father() {
console.log("trigger father");
},
child() {
console.log("trigger child");
},
grandSon() {
console.log("trigger granSon");
},
當(dāng)點擊孫子盒子時,會產(chǎn)生冒泡,由內(nèi)而外,依次順序執(zhí)行事件:

我們給處于中間的子盒子添加.capture修飾符捕獲冒泡事件,這樣當(dāng)點擊孫子盒子時,會先執(zhí)行子盒子后,再按正常冒泡順序依次執(zhí)行孫子盒子與父盒子:
<div class="child" @click.capture="child">

四.self修飾符:
將事件綁定到自身,只有自身才能觸發(fā),通常用于避免冒泡事件的影響。
以下面這個例子,比如有一個天藍色父盒子,里面包裹了一個綠色子盒子,里面再包裹了一個橙色孫子盒子,分別綁定點擊事件將輸出不同內(nèi)容:
<div class="father" @click="father">
<div class="child" @click="child">
<div class="grandSon" @click="grandSon"></div>
</div>
.father {
width: 200px;
height: 200px;
background-color: skyblue;
}
.child {
width: 100px;
height: 100px;
background-color: green;
}
.grandSon {
width: 50px;
height: 50px;
background-color: orange;
}
father() {
console.log("trigger father");
},
child() {
console.log("trigger child");
},
grandSon() {
console.log("trigger granSon");
},
正常情況下,當(dāng)點擊不同盒子時,會產(chǎn)生冒泡,由內(nèi)而外,依次順序執(zhí)行事件:

我們給處于中間的子盒子添加.self修飾符,這樣當(dāng)點擊孫子盒子時,按照正常冒泡邏輯,會依次觸發(fā)孫子、兒子、父親的點擊事件,但是因為子盒子添加了.self修飾符,那么孫子的冒泡就不能影響到子盒子了,冒泡無效,只有子盒子自己被點擊才會觸發(fā)它的點擊事件。
<div class="child" @click.self="child">

五.once修飾符:
顧名思義,就是事件只能觸發(fā)一次,比如給一個盒子綁定點擊事件,點擊后輸出內(nèi)容:
<div class="father" @click="father"></div>
.father {
width: 200px;
height: 200px;
background-color: skyblue;
}
father() {
console.log("trigger father");
},
正常效果:

添加.once修飾符,點擊事件只能觸發(fā)一次,多點沒有了:
<div class="father" @click.once="father"></div>

六.passive修飾符:
這個不方便舉例,我就直接結(jié)合vue官方文檔的介紹了:
Vue 還對應(yīng) addEventListener 中的 passive 選項提供了 .passive 修飾符。
<!-- 滾動事件的默認行為 (即滾動行為) 將會立即觸發(fā) --> <!-- 而不會等待 `onScroll` 完成 --> <!-- 這其中包含 `event.preventDefault()` 的情況 --> <div v-on:scroll.passive="onScroll">...</div>
這個 .passive 修飾符會執(zhí)行默認方法,尤其能夠提升移動端的性能。
問題來了,passive 修飾符會執(zhí)行默認方法?提高性能?默認方法本來就會執(zhí)行,要它干嘛?
簡單來說,其實每次事件產(chǎn)生,瀏覽器都會去查詢一下是否有preventDefault阻止該次事件的默認動作。我們加上passive就是為了告訴瀏覽器,不用查詢了,我們沒用preventDefault阻止默認動作。所以說,瀏覽器就不用去檢查了,既然不用檢查了,那效率就上來了,性能那肯定就加強了。特別是在移動端,用戶手勢操作那么快,執(zhí)行效率就很重要了。
不要把 .passive 和 .prevent 一起使用,因為 .prevent 將會被忽略,同時瀏覽器可能會向你展示一個警告。請記住,.passive 會告訴瀏覽器你不想阻止事件的默認行為。
七. 按鍵修飾符、系統(tǒng)修飾符:
1.按鍵修飾符:
在監(jiān)聽鍵盤事件時,我們經(jīng)常需要檢查詳細的按鍵。Vue 允許為 v-on 在監(jiān)聽鍵盤事件時添加按鍵修飾符。簡單來說,我們在綁定按鍵事件時,可以通過修飾符快速指定只有點擊某個鍵才會觸發(fā)。
vue提供的常用按鍵碼別名的修飾符如下:
.enter .tab .delete (捕獲“刪除”和“退格”鍵) .esc .space .up .down .left .right
比如,有一個input輸入框,綁定一個keyup按鍵松開事件,觸發(fā)時輸出內(nèi)容:
<input type="text" @keyup="outPut" />
outPut() {
console.log("outPut!");
},
只要有按鍵松開都會觸發(fā):

按鍵修飾符,后面當(dāng)我按回車鍵時才會觸發(fā)事件:
<input type="text" @keyup.enter="outPut" />

2.系統(tǒng)修飾符:
這個跟按鍵修飾符一樣的,就不多介紹了,我直接引用vue官方文檔的介紹了:
可以用如下修飾符來實現(xiàn)僅在按下相應(yīng)按鍵時才觸發(fā)鼠標或鍵盤事件的監(jiān)聽器。
.ctrl .alt .shift .meta
如:
<!-- Alt + C --> <input v-on:keyup.alt.67="clear"> <!-- Ctrl + Click --> <div v-on:click.ctrl="doSomething">Do something</div>
請注意修飾鍵與常規(guī)按鍵不同,在和 keyup 事件一起用時,事件觸發(fā)時修飾鍵必須處于按下狀態(tài)。換句話說,只有在按住 ctrl 的情況下釋放其它按鍵,才能觸發(fā) keyup.ctrl。而單單釋放 ctrl 也不會觸發(fā)事件。如果你想要這樣的行為,請為 ctrl 換用 keyCode:keyup.17。
八.總結(jié):
?到這基本上對vue事件修飾符的介紹就差不多了,并不難,再上一次表格,強化記憶:
| 事件修飾符 | 功能作用 |
| .stop | 阻止冒泡 |
| .prevent | 阻止默認事件 |
| .capture | 捕獲冒泡 |
| .self | 綁定自身,自身才能觸發(fā) |
| .once | 事件只能觸發(fā)一次 |
| .passive | 對dom默認事件性能優(yōu)化 |
到此這篇關(guān)于案例實操vue事件修飾符帶你快速了解與應(yīng)用的文章就介紹到這了,更多相關(guān)vue事件修飾符了解與應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3+vite中使用import.meta.glob的操作代碼
在vue2的時候,我們一般引入多個js或者其他文件,一般使用? require.context 來引入多個不同的文件,但是vite中是不支持 require的,他推出了一個功能用import.meta.glob來引入多個,單個的文件,下面通過本文介紹vue3+vite中使用import.meta.glob,需要的朋友可以參考下2022-11-11
vue實現(xiàn)的多頁面項目如何優(yōu)化打包的步驟詳解
這篇文章主要介紹了vue實現(xiàn)的多頁面項目如何優(yōu)化打包的步驟詳解,文中通過示例代碼以及圖文介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
uniapp小程序上傳文件webapi后端項目asp.net完整代碼
在uniapp中,實現(xiàn)文件上傳功能也變得非常簡單,下面這篇文章主要給大家介紹了關(guān)于uniapp小程序上傳文件webapi后端項目asp.net的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-07-07
vue3在table里使用elementUI的form表單驗證的示例代碼
這篇文章主要介紹了vue3在table里使用elementUI的form表單驗證的示例代碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-12-12

