亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue?nextTick獲取更新后的DOM的實現(xiàn)

 更新時間:2022年01月25日 09:14:36   作者:Skuld_yi's?Blog  
本文主要介紹了Vue?nextTick獲取更新后的DOM的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

前兩天在開發(fā)時遇到一個需求:打開對話框的時候自動聚焦其中的輸入框。由于原生的 autofocus 屬性不起作用,需要使用組件庫提供的 focus 方法手動手動獲取焦點。于是有如下代碼:

<el-button @click="openDialog">點擊打開 Dialog</el-button>

<el-dialog :visible.sync="dialogVisible">
? <el-input v-model="input" ref="input"></el-input>
</el-dialog>
methods: {
? openDialog() {
? ? this.dialogVisible = true;
? ? const input = this.$refs.input;
? ? input.focus();
? },
},

結果報錯了,原因是沒有獲取到 input 組件;通過 log,也驗證了 this.$refs.input 的值確實是 undefined。但是經(jīng)過測試,如果對話框默認狀態(tài)是打開的,就不會報錯;明明組件就在那,為什么獲取不到呢?

生命周期 update

經(jīng)過分析,這種現(xiàn)象是由于 Vue 實例的更新機制造成的。從下方的生命周期圖(局部)中可以看出,組件裝載好之后,遇到數(shù)據(jù)變化時將重新渲染虛擬 DOM(可以理解為 HTML 中的組件節(jié)點)。在本例中,隱藏的 Dialog 組件(以及其中的 input 組件)本來并沒有渲染在 DOM 中,是在觀察到 dialogVisible 屬性變?yōu)?true 后再進行更新渲染的。

而網(wǎng)頁渲染通常是一個異步任務,因此在 visible 屬性剛剛更改時(一個函數(shù)中是同步過程),DOM 渲染還沒有進行,因此自然獲取不到此時還不存在的 input 組件了。

關于異步、JS任務隊列、宏任務與微任務等概念的更多介紹,可參考博文JS多線程:任務隊列

為了更直觀地展示這個過程,可以在更新前后的鉤子函數(shù)中試圖獲取組件并進行打?。?/p>

beforeUpdate() {
? console.log("beforeUpdate");
? const input = this.$refs.input;
? console.log(input);
},
updated() {
? console.log("updated");
? const input = this.$refs.input;
? console.log(input);
},
methods: {
? openDialog() {
? ? this.dialogVisible = true;
? ? console.log("click open");
? },
},

結果如下,可以驗證之前的分析和猜想:

click open
beforeUpdate
undefined
updated
VueComponent {...}

Vue.nextTick

為了解決這個問題,Vue 提供了全局 api Vue.nextTick(),它的作用是提供下次 DOM 更新之后的回調(diào)。也就是說,在更新數(shù)據(jù)后調(diào)用 api,就能夠獲取到重新渲染后的 DOM 并進行相關操作。

nextTick 方法可以廣泛適用于各種需要在數(shù)據(jù)更新后對相關 DOM 進行操作的情景,例如 v-if 、watch 等。

在上文的例子中再加入 nextTick:

openDialog() {
? this.dialogVisible = true;
? console.log("click open");
? this.$nextTick(function () {
? ? console.log("next tick");
? ? const input = this.$refs.input;
? ? console.log(input);
? ? input.focus();
? });
},

可以看到,回調(diào)確實是在 DOM 更新之后,也就是 updated 執(zhí)行之后才執(zhí)行的。獲取組件與手動獲得焦點的操作也能夠正確執(zhí)行了。

click open
beforeUpdate
undefined
updated
VueComponent {...}
next tick
VueComponent {...}

Promise

如果沒有提供回調(diào)參數(shù),并且瀏覽器支持 Promise,調(diào)用 nextTick 將返回一個 Promise。也就是說下面幾種寫法是等價的(環(huán)境支持的情況下):

Vue.nextTick(function () {...})
Vue.nextTick(() => {...})

Vue.nextTick().then(function () {...})
Vue.nextTick().then(() => {...})

關于 Promise 的介紹和用法,可以參考博文 JS Promise。

結語&參考資料

以上是個人對 Vue 中 nextTick api 的一些理解與思考,希望能給你提供幫助。如果有問題或疏漏之處,歡迎在評論中討論與指正。

參考資料:

Vue 文檔 - api

Vue 文檔 - 實例

到此這篇關于Vue nextTick獲取更新后的DOM的實現(xiàn)的文章就介紹到這了,更多相關Vue nextTick獲取更新后的DOM內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue點擊自增和求和的實例代碼

    vue點擊自增和求和的實例代碼

    今天小編就為大家分享一篇vue點擊自增和求和的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue實現(xiàn)移動端圖片裁剪上傳功能

    vue實現(xiàn)移動端圖片裁剪上傳功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端圖片裁剪上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • vue-cli配置文件——config篇

    vue-cli配置文件——config篇

    這篇文章主要介紹了vue-cli中的webpack是如何配置的,本篇文章主要是分析vue中關于config文件夾中的相關代碼,config的文件結構,感興趣的朋友參考下本文
    2018-01-01
  • vue + axios get下載文件功能

    vue + axios get下載文件功能

    這篇文章主要為大家詳細介紹了vue + axios get下載文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Vite結合Vue刪除指定環(huán)境的console.log問題

    Vite結合Vue刪除指定環(huán)境的console.log問題

    這篇文章主要介紹了Vite結合Vue刪除指定環(huán)境的console.log問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue3父子同信的雙向數(shù)據(jù)的項目實現(xiàn)

    vue3父子同信的雙向數(shù)據(jù)的項目實現(xiàn)

    我們知道的是,父傳子的通信,和子傳父的通信,那如何實現(xiàn)父子相互通信的呢,本文就來詳細的介紹一下,感興趣的可以了解一下
    2023-08-08
  • Vue實現(xiàn)拖拽式分割布局

    Vue實現(xiàn)拖拽式分割布局

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)拖拽式分割布局,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue頁面監(jiān)聽鍵盤按鍵的方法總結

    Vue頁面監(jiān)聽鍵盤按鍵的方法總結

    在Vue頁面中,可以使用多種方法來監(jiān)聽鍵盤按鍵,這篇文章主要為大家整理了五種常用的方法,文中的示例代碼講解詳細,需要的小伙伴可以參考下
    2023-10-10
  • Vue加載json文件的方法簡單示例

    Vue加載json文件的方法簡單示例

    這篇文章主要介紹了Vue加載json文件的方法,結合實例形式分析了vue.js針對json文件的加載及數(shù)據(jù)讀取等相關操作技巧,需要的朋友可以參考下
    2019-01-01
  • 一步一步實現(xiàn)Vue的響應式(對象觀測)

    一步一步實現(xiàn)Vue的響應式(對象觀測)

    這篇文章主要介紹了一步一步實現(xiàn)Vue的響應式(對象觀測),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09

最新評論