詳解Vue的鍵盤事件
在js中我們要獲取一個按鍵的編碼通常需要通過(keydown/keyup)去綁定一個事件,再通過默認參數(shù)event中的keyCode屬性去取得編碼。如果我們要實現(xiàn)按固定的鍵才能觸發(fā)事件時就需要在事件中進行不斷的判斷,這樣會顯的很麻煩,如
var input = document.querySelector('input')
input.onkeyup = function (e) {
if (e.keyCode == 13)
console.log('我是回車鍵')
}在vue中就為我們一些常用的按鍵提供了別名,并且只需要我們在事件后加上相應別名即可,不需要我們手動的在事件中進行判斷。
常用按鍵別名
Vue中為一些常用的按鍵綁定了別名,分別有以下幾種。
- 上箭頭:up
- 下箭頭:down
- 左箭頭:left
- 右箭頭:right
- 空格:space
- 換行:tab
- 退出:esc
- 回車:enter
- 刪除/退格:delete
別名可用來限制鍵盤事件(keydown、keyup),只有按下鍵的是與別名一致時才會去執(zhí)行所綁定的事件
<input v-on:keyup.enter="showtip" type="text"> 只有按下回車鍵時才會執(zhí)行showtip方法
另外,tab鍵只適合與keydown一起使用,在瀏覽器中tab本身就已經(jīng)綁定了事件:切換焦點,所以在按下放開tab鍵后就會觸動默認的事件,而忽視了keyup所綁定的事件。而使用keydown就能避過這一情況,在tab按下的那一瞬間便會執(zhí)行所綁定的事件。
未提供別名的鍵
另外,在vue中未提供別名的按鍵,vue也為我們提供了一種方法去使用。vue中規(guī)定未提供別名的按鍵,可使用按鍵原始的key值去綁定,所謂key值就是由event.key獲得的值。如
var input = document.querySelector('input')
input.onkeyup = function (e) {
console.log(e.key)
}以上代碼在我們按下任意一鍵時在控制臺就會輸出對應的key值,分別按下大小寫切換鍵、Q以及W鍵會得到以下值
我們就可以使用key值作為按鍵的別名,特別要注意的是如果key值是單個字母或單詞直接使用key值就可以了,但是如果由多個單詞組成如大小寫切換鍵就為兩個單詞的結合,這個時候就要把key值進行改動,使用短橫線命名法則將CapsLock-->caps-lock就可以使用了
<input v-on:keyup.Q="showtip" type="text"> //只有按下q鍵時才會執(zhí)行showtip方法 <input v-on:keyup.caps-lock="showtips" type="text"> //只有按下capslock鍵時才會執(zhí)行showtips方法
系統(tǒng)修飾鍵
所謂系統(tǒng)修飾鍵就是ctrl、alt、shift等。這些鍵的使用比較來說有點復雜,主要分為以下兩種情況
1.當觸發(fā)事件為keyup時,按下修飾鍵的同時要按下其他鍵,再釋放其他鍵,事件才能被觸發(fā)。
<input v-on:keyup.Alt="showtips" type="text"> //按下alt鍵后再按任意一鍵,然后再釋放任意鍵后便會執(zhí)行showtips方法 //以上的步驟太過麻煩我們可以這樣寫 <input v-on:keyup.Alt.y="showtips" type="text"> //當按alt y時就會觸發(fā)事件而不用先按alt再按y再放y
當觸發(fā)事件為keydown時,直接按下修飾鍵。
<input v-on:keydown.Alt="showtips" type="text"> //只有按下alt鍵時才會執(zhí)行showtips方法
自定義按鍵別名
vue中為我們提供了自定義按鍵別名的方法,通過(Vue.config.keyCodes.自定義鍵名=鍵碼)的方式去定義
<input v-on:keydown.en="showtips" type="text"> //只有按下回車鍵時才會執(zhí)行showtips方法 Vue.config.keyCodes.en=13 //13是回車鍵的鍵碼,將他的別名定義為en
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!
相關文章
vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn)
這篇文章主要介紹了vue+element 模態(tài)框表格形式的可編輯表單實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06
vue+axios 前端實現(xiàn)登錄攔截的兩種方式(路由攔截、http攔截)
本文通過實例代碼給大家介紹了vue+axios 前端實現(xiàn)登錄攔截的方法,主要通過路由攔截和http攔截,具體實例代碼大家跟隨小編一起通過本文學習吧2018-10-10
你不知道的Vue技巧之--開發(fā)一個可以通過方法調用的組件(推薦)
這篇文章主要介紹了你不知道的Vue技巧之--開發(fā)一個可以通過方法調用的組件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04

