十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章將為大家詳細(xì)講解有關(guān)vue怎么實(shí)現(xiàn)綁定事件,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的南海網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
一、前言
vuejs中的事件綁定,使用
來完成的,這里函數(shù)名是定義在Vue實(shí)例中的methods對(duì)象中的,Vue實(shí)例可以直接訪問其中的方法。
二、事件綁定方式
1、 直接在標(biāo)簽中寫js方法
2、調(diào)用method的辦法
export default { data () { return { msg: '你好vue', list:[] } }, methods:{ run:function(){ alert('這是一個(gè)方法'); } } }
(1)方法傳參,方法直接在調(diào)用時(shí)在方法內(nèi)傳入?yún)?shù)
deleteData(val){ alert(val); },
(2)傳入事件對(duì)象
eventFn(e){ console.log(e); // e.srcElement dom節(jié)點(diǎn) e.srcElement.style.background='red'; console.log(e.srcElement.dataset.aid); /*獲取自定義屬性的值*/ }
三、事件修飾符
1、stop //阻止事件繼續(xù)傳播 即阻止它的捕獲和冒泡過程
方法一: @click='show($event)'
我們有了事件對(duì)象后,我們函數(shù)中是不是就可以利用原生中的e.cancelBubble=true
;
方法二: @click.stop='show()'
只要在事件后面加 .stop 就可以阻止事件冒泡
舉個(gè)例子:
實(shí)例:如下點(diǎn)擊內(nèi)部點(diǎn)擊,阻止了冒泡過程,即只執(zhí)行tz這個(gè)方法,如果不加.stop,先執(zhí)行tz方法,后執(zhí)行g(shù)ett方法。即通過了冒泡這個(gè)過程。
外部點(diǎn)擊內(nèi)部點(diǎn)擊
2、prevent //阻止默認(rèn)事件:
方法一: @click='show($event)'
我們有了事件對(duì)象后,我們函數(shù)中是不是就可以利用原生中的 e.preventDefault();
方法二: @click.prevent='show()'
只要在事件后面加 .prevent 就可以阻止默認(rèn)事件。
舉個(gè)例子:阻止了a標(biāo)簽的默認(rèn)刷新
3、capture // 添加事件監(jiān)聽器時(shí)使用事件捕獲模式,即在捕獲模式下觸發(fā)
實(shí)例:在點(diǎn)擊最里層的點(diǎn)擊6時(shí),gett方法先執(zhí)行,因?yàn)間ett方法在捕獲模式執(zhí)行的,先與冒泡事件。下列執(zhí)行順序 geet->set->tz ,因?yàn)楹髠z個(gè)還是冒泡模式下觸發(fā)的事件。
外部點(diǎn)擊5內(nèi)部點(diǎn)擊5點(diǎn)擊6
4、self //當(dāng)前元素自身時(shí)觸發(fā)處理函數(shù)時(shí)才會(huì)觸發(fā)函數(shù)
原理:是根據(jù)event.target確定是否當(dāng)前元素本身,來決定是否觸發(fā)的事件/函數(shù)
實(shí)例:如果點(diǎn)擊內(nèi)部點(diǎn)擊2,冒泡不會(huì)執(zhí)行g(shù)ett方法,因?yàn)閑vent.target指的是內(nèi)部點(diǎn)擊2的dom元素,不是外部點(diǎn)擊1的,所以不會(huì)觸發(fā)自己的點(diǎn)擊事件。
外部點(diǎn)擊1內(nèi)部點(diǎn)擊2
5、once //只觸發(fā)一次
實(shí)例:
6、鍵盤事件
方法一:@keydown='show()'
當(dāng)然我們傳個(gè)$event 也可以在函數(shù)中獲 ev.keyCode
if(ev.keyCode==13){ alert('你按了回車鍵!') }
方法二:
回車執(zhí)行 上鍵執(zhí)行 下鍵執(zhí)行 左鍵執(zhí)行 右鍵執(zhí)行
關(guān)于“vue怎么實(shí)現(xiàn)綁定事件”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。