溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue怎么實現(xiàn)綁定事件

發(fā)布時間:2021-04-02 11:02:30 來源:億速云 閱讀:235 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細講解有關vue怎么實現(xiàn)綁定事件,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、前言

  vuejs中的事件綁定,使用<v-on:事件名 = 函數(shù)名>來完成的,這里函數(shù)名是定義在Vue實例中的methods對象中的,Vue實例可以直接訪問其中的方法。

二、事件綁定方式

1、 直接在標簽中寫js方法

 <button v-on:click="alert('hi')">執(zhí)行方法的第一種寫法</button>

2、調(diào)用method的辦法

<button v-on:click="run()">執(zhí)行方法的第一種寫法</button>
 
  <button @click="run()">執(zhí)行方法的 簡寫 寫法</button>
export default {  
  data () { 
  return {
   msg: '你好vue',
   list:[]  
  }
  },
  methods:{
   run:function(){
    alert('這是一個方法');
    }
   }
 }

(1)方法傳參,方法直接在調(diào)用時在方法內(nèi)傳入?yún)?shù)

 <button @click="deleteData('111')">執(zhí)行方法傳值111</button>
  <button @click="deleteData('222')">執(zhí)行方法傳值2222</button>
 deleteData(val){
   alert(val);
  },

(2)傳入事件對象

 <button data-aid='123' @click="eventFn($event)">事件對象</button>
eventFn(e){
   console.log(e);
   // e.srcElement dom節(jié)點
   e.srcElement.style.background='red';
   console.log(e.srcElement.dataset.aid); /*獲取自定義屬性的值*/
  }

三、事件修飾符

1、stop  //阻止事件繼續(xù)傳播 即阻止它的捕獲和冒泡過程

方法一: @click='show($event)'    我們有了事件對象后,我們函數(shù)中是不是就可以利用原生中的e.cancelBubble=true

方法二: @click.stop='show()'    只要在事件后面加 .stop  就可以阻止事件冒泡

舉個例子:

實例:如下點擊內(nèi)部點擊,阻止了冒泡過程,即只執(zhí)行tz這個方法,如果不加.stop,先執(zhí)行tz方法,后執(zhí)行gett方法。即通過了冒泡這個過程。

<div v-on:click="gett">
 外部點擊
 <div v-on:click.stop="tz">內(nèi)部點擊</div>
</div>

2、prevent    //阻止默認事件:

方法一: @click='show($event)'    我們有了事件對象后,我們函數(shù)中是不是就可以利用原生中的 e.preventDefault();

方法二: @click.prevent='show()'   只要在事件后面加 .prevent  就可以阻止默認事件。

舉個例子:阻止了a標簽的默認刷新

<a href="" v-on:click.prevent>點擊</a>

3、capture // 添加事件監(jiān)聽器時使用事件捕獲模式,即在捕獲模式下觸發(fā)

實例:在點擊最里層的點擊6時,gett方法先執(zhí)行,因為gett方法在捕獲模式執(zhí)行的,先與冒泡事件。下列執(zhí)行順序 geet->set->tz ,因為后倆個還是冒泡模式下觸發(fā)的事件。

<div v-on:click.capture="gett">外部點擊5
 <div v-on:click="tz">內(nèi)部點擊5
  <div v-on:click="set">點擊6</div>
 </div>
</div>

4、self //當前元素自身時觸發(fā)處理函數(shù)時才會觸發(fā)函數(shù)

原理:是根據(jù)event.target確定是否當前元素本身,來決定是否觸發(fā)的事件/函數(shù)

實例:如果點擊內(nèi)部點擊2,冒泡不會執(zhí)行gett方法,因為event.target指的是內(nèi)部點擊2的dom元素,不是外部點擊1的,所以不會觸發(fā)自己的點擊事件。

<div v-on:click.self="gett">
 外部點擊1
 <div v-on:click="tz">內(nèi)部點擊2</div>
</div>

5、once //只觸發(fā)一次

實例:

<div  v-on:click.once="tz">once</div>

6、鍵盤事件

方法一:@keydown='show()'    

當然我們傳個$event  也可以在函數(shù)中獲 ev.keyCode

if(ev.keyCode==13){
 alert('你按了回車鍵!')
}

方法二:

 <input type="text" @keyup.enter="show()">回車執(zhí)行
 <input type="text" @keydown.up='show()' >上鍵執(zhí)行
 <input type="text" @keydown.down='show()' >下鍵執(zhí)行
 <input type="text" @keydown.left='show()' >左鍵執(zhí)行
 <input type="text" @keydown.right='show()' >右鍵執(zhí)行

關于“vue怎么實現(xiàn)綁定事件”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

vue
AI