真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Vue2.xTodo之自定義指令實現(xiàn)自動聚焦的方法

我們希望用戶雙擊 todo 進入編輯狀態(tài)后輸入框自動獲取焦點,而不是需要先手動點一下。input 元素有一個 focus 方法可以來幫我們完成這個事情,但現(xiàn)在的問題是如何在 Vue 中獲得這個 input 元素,從而來操作它。Vue 的自定義指令可以完成這個功能。

成都創(chuàng)新互聯(lián)2013年至今,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目網(wǎng)站制作、成都網(wǎng)站設計網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元臺山做網(wǎng)站,已為上家服務,為臺山各地企業(yè)和個人服務,聯(lián)系電話:18982081108

我們先來看看 Vue 官網(wǎng)的一個示例:

然而,有的情況下,你仍然需要對普通 DOM 元素進行底層操作,這時候就會用到自定義指令。舉個聚焦輸入框的例子,如下:

一個輸入框:

當頁面加載時,該元素將獲得焦點 (注意: autofocus 在移動版 Safari 上不工作)。事實上,只要你在打開這個頁面后還沒點擊過任何內(nèi)容,這個輸入框就應當還是處于聚焦狀態(tài)?,F(xiàn)在讓我們用指令來實現(xiàn)這個功能:

 // 注冊一個全局自定義指令 `v-focus` 

Vue.directive('focus', { // 當被綁定的元素插入到 DOM 中時…… inserted: function (el) { // 聚焦元素 el.focus() } })

如果想注冊局部指令,組件中也接受一個 directives 的選項:

directives: { focus: { // 指令的定義 inserted: function (el) { el.focus() } } }

指令是什么,就是用來指導被綁定的元素的行為,我們之前接觸過 v-if、v-model、v-bind 等指令,官方文檔說的非常清楚,我們可以自己注冊一個指令,然后實現(xiàn)某些鉤子函數(shù),從而指定被綁定元素的行為。這里我們依葫蘆畫瓢,實現(xiàn)一個 focus 指令,這個指令實現(xiàn)了 inserted 鉤子函數(shù),這個函數(shù)在被綁定的元素被插入 dom 時觸發(fā),且被綁定的元素會作為參數(shù)傳入鉤子函數(shù),我們就可以在函數(shù)中對它操作。

我們在 Vue 對象中聲明局部指令:


然后就可以使用這個指令了,把它綁定到編輯框,這樣編輯框出現(xiàn)時指令就被觸發(fā),從而聚焦。


注意因為元素一旦出現(xiàn)一定要聚焦的,所以條件始終為 true。

現(xiàn)在用戶體驗好多了!快打開瀏覽器體驗一下吧!

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


當前名稱:Vue2.xTodo之自定義指令實現(xiàn)自動聚焦的方法
分享網(wǎng)址:http://weahome.cn/article/jsdjej.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部