欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年01月08日 08:27:19   作者:追夢人物  
我們希望用戶雙擊 todo 進入編輯狀態(tài)后輸入框自動獲取焦點,而不是需要先手動點一下。這篇文章主要介紹了Vue 2.x Todo之自定義指令實現(xiàn)自動聚焦,非常具有實用價值,需要的朋友可以參考下

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

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

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

一個輸入框:

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

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

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

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

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

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

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

<script>
  let id = 0; // 用于 id 生成
  var app = new Vue({
    ...
    methods: {
      ...
    },
    directives: {
      focus: {
        inserted: function (el) {
          el.focus()
        }
      }
    }
  })
</script>

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

<input type="text" 
    value="編輯 todo..."
    v-focus="true"
    v-if="editedTodo!==null && editedTodo.id===todo.id"
    v-model="todo.title"
    @keyup.enter="editDone(todo)"
    @keyup.esc="cancelEdit(todo)"/>

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vite配置@別名以及讓vscode智能提示路經(jīng)的步驟

    vite配置@別名以及讓vscode智能提示路經(jīng)的步驟

    這篇文章主要給大家介紹了關(guān)于vite配置@別名以及讓vscode智能提示路經(jīng)的步驟,文中通過代碼示例以及圖文介紹的非常詳細,對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-08-08
  • electron-vue開發(fā)環(huán)境內(nèi)存泄漏問題匯總

    electron-vue開發(fā)環(huán)境內(nèi)存泄漏問題匯總

    這篇文章主要介紹了electron-vue開發(fā)環(huán)境內(nèi)存泄漏問題匯總,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue打開新窗口并實現(xiàn)傳參的圖文實例

    vue打開新窗口并實現(xiàn)傳參的圖文實例

    這篇文章主要給大家介紹了關(guān)于vue打開新窗口并實現(xiàn)傳參的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 基于vue-cli vue-router搭建底部導(dǎo)航欄移動前端項目

    基于vue-cli vue-router搭建底部導(dǎo)航欄移動前端項目

    這篇文章主要介紹了基于vue-cli vue-router搭建底部導(dǎo)航欄移動前端項目,項目中主要用了Flex布局,以及viewport相關(guān)知識,已達到適應(yīng)各終端屏幕的目的。需要的朋友可以參考下
    2018-02-02
  • Vue使用Axios和elementui實現(xiàn)查詢分頁功能

    Vue使用Axios和elementui實現(xiàn)查詢分頁功能

    當(dāng)今的Web開發(fā)趨勢中,前后端分離已經(jīng)成為一種流行的架構(gòu)模式,它將前端和后端的開發(fā)分離開來,使得前端和后端可以獨立進行開發(fā)和部署,本文給大家介紹了Vue使用Axios和elementui實現(xiàn)查詢分頁功能,需要的朋友可以參考下
    2024-06-06
  • vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法(使用c3平滑屬性實現(xiàn))

    vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法(使用c3平滑屬性實現(xiàn))

    這篇文章主要介紹了vue中實現(xiàn)點擊按鈕滾動到頁面對應(yīng)位置的方法,這段代碼主要使用c3平滑屬性實現(xiàn),需要的朋友可以參考下
    2019-12-12
  • vue圓形進度條環(huán)形進度條組件內(nèi)部顯示圖片示例

    vue圓形進度條環(huán)形進度條組件內(nèi)部顯示圖片示例

    這篇文章主要為大家介紹了vue圓形進度條環(huán)形進度條組件內(nèi)部顯示圖片示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Vue中用watch一次監(jiān)聽多個值變化的示例詳解

    Vue中用watch一次監(jiān)聽多個值變化的示例詳解

    在Vue中,watch 本身不能監(jiān)聽多個變量,但我們可以通過返回具有計算屬性的對象然后監(jiān)聽該對象,從而實現(xiàn)一次性“監(jiān)聽多個變量”,本文給大家介紹了Vue中用watch一次監(jiān)聽兩個值變化的示例,需要的朋友可以參考下
    2024-01-01
  • Vue動態(tài)類的幾種使用方法總結(jié)

    Vue動態(tài)類的幾種使用方法總結(jié)

    這篇文章主要介紹了Vue動態(tài)類的幾種使用方法總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • 在Vue中進行數(shù)據(jù)分頁的實現(xiàn)方法

    在Vue中進行數(shù)據(jù)分頁的實現(xiàn)方法

    在前端開發(fā)中,數(shù)據(jù)分頁是一個常見的需求,特別是當(dāng)處理大量數(shù)據(jù)時,Vue作為一款流行的JavaScript框架,提供了強大的工具和生態(tài)系統(tǒng)來實現(xiàn)數(shù)據(jù)分頁,本文將介紹如何在Vue中進行數(shù)據(jù)分頁,以及如何設(shè)計一個通用的分頁組件,需要的朋友可以參考下
    2023-10-10

最新評論