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

使用this.$nextTick()獲取不到數(shù)據(jù)更新后的this.$refs.xxx.及場景分析

 更新時間:2023年02月06日 09:46:17   作者:Rised  
今天遇到了這樣一個場景,在數(shù)據(jù)更新之后,使用this.$nextTick(()=>{console.log(this.$refs.xxx)}) 獲取不到改dom,但是用setTimeout能夠獲取到,在此記錄一下,感興趣的朋友跟隨小編一起看看吧

使用this.$nextTick()獲取不到數(shù)據(jù)更新后的this.$refs.xxx.

今天遇到了這樣一個場景,在數(shù)據(jù)更新之后,使用this.$nextTick(()=>{console.log(this.$refs.xxx)}) 獲取不到改dom,但是用setTimeout能夠獲取到,在此記錄一下。

先看代碼

  
<!--這是模板代碼,父級用的v-else-if,與父級同級的還有兩個盒子,分別用v-if和v-else控制著-->
<div ref="articleContent" class="right" v-html="articles.content"></div>
 
 
 
//這是script代碼
 
 mounted() {
    
        this.getArticlesDetail()
    
  },
  methods: {
   async getArticlesDetail(){
        try {
            
            const {data}= await getArticlesDetail(this.articleId);
            /* vue數(shù)據(jù)更新是異步的 ,在這一步數(shù)據(jù)加載出來,但是組件還沒沒有渲染出來,因為在組件中有個v-if判斷,在數(shù)據(jù)加載出來之后,才能渲染出來組件*/
            /* console.log(this.$refs.articleContent) */
            /* 所以要放在定時器是異步執(zhí)行,試了用this.$nextTick,不行 */
          /*  */
            this.articles = data
            /* 只能用setitmeout是因為數(shù)據(jù)在在下個Event Loop中也出不來,這是因為v-if中的條件在下次事件循環(huán)中也不一定能夠滿足。但是setTimeout的執(zhí)行時機是沒有辦法確定前邊的任務到底需要多長時間執(zhí)行完 */
              this.$nextTick(() => {
                console.log(this.$refs.articleContent)
            });
            console.log(data)
        } catch (error) {
            if(error.response && error.response.status===404){
                this.errStatus=404;
                this.$toast('服務器錯誤')
            }
            console.log(error)
            this.$toast('請求失敗,請稍后再試')
        }
        /* 無論成功失敗都要調(diào)用loading為false,關(guān)閉它 */
        this.loading=false
    }
  },

 這是控制臺打印的效果.

 獲取不到.

vue官網(wǎng)中對于vue.nextTick()中的解釋:

 也就是說在下個事件循環(huán)中沒有滿足v-if中的條件,所以沒有獲取到數(shù)據(jù)。

在vue 中的devtools中 可以獲取到。

然后我們修改成setTimeout

  
<!--這是模板代碼,父級用的v-else-if,與父級同級的還有兩個盒子,分別用v-if和v-else控制著-->
<div ref="articleContent" class="right" v-html="articles.content"></div>
 
 
 
//這是script代碼
 
 mounted() {
    
        this.getArticlesDetail()
    
  },
  methods: {
   async getArticlesDetail(){
        try {
            
            const {data}= await getArticlesDetail(this.articleId);
            /* vue數(shù)據(jù)更新是異步的 ,在這一步數(shù)據(jù)加載出來,但是組件還沒沒有渲染出來,因為在組件中有個v-if判斷,在數(shù)據(jù)加載出來之后,才能渲染出來組件*/
            /* console.log(this.$refs.articleContent) */
            /* 所以要放在定時器是異步執(zhí)行,試了用this.$nextTick,不行 */
          /*  */
            this.articles = data
            /* 只能用setitmeout是因為數(shù)據(jù)在在下個Event Loop中也出不來,這是因為v-if中的條件在下次事件循環(huán)中也不一定能夠滿足。但是setTimeout的執(zhí)行時機是沒有辦法確定前邊的任務到底需要多長時間執(zhí)行完 */
              setTimeout(() => {
                console.log(this.$refs.articleContent)
            });
            console.log(data)
        } catch (error) {
            if(error.response && error.response.status===404){
                this.errStatus=404;
                this.$toast('服務器錯誤')
            }
            console.log(error)
            this.$toast('請求失敗,請稍后再試')
        }
        /* 無論成功失敗都要調(diào)用loading為false,關(guān)閉它 */
        this.loading=false
    }
  },

這是控制臺打印的效果

 可以看出來有效果.

在vue中的devtools中也有,

這是為什么呢? 

只能用setitmeout是因為數(shù)據(jù)在在下個Event Loop中也出不來,這是因為v-if中的條件在下次事件循環(huán)中也不一定能夠滿足。但是setTimeout的執(zhí)行時機是沒有辦法確定前邊的任務到底需要多長時間執(zhí)行完,所以使用setTimeout會更好。

補充:詳解Vue中this.$nextTick()用法

語法:

this.$nextTick( [ callback ] )

用法: 

 this.$nextTick將回調(diào)延遲到下次 DOM 更新循環(huán)之后執(zhí)行。在修改數(shù)據(jù)之后立即使用它,然后等待 DOM 更新。它跟全局方法 Vue.nextTick 一樣,不同的是回調(diào)的 this 自動綁定到調(diào)用它的實例上,等同于updated生命周期函數(shù)

updated用法:由于數(shù)據(jù)更改導致的虛擬 DOM 重新渲染和打補丁,在這之后會調(diào)用該鉤子。當這個鉤子被調(diào)用時,組件 DOM 已經(jīng)更新,所以你現(xiàn)在可以執(zhí)行依賴于 DOM 的操作。

示例: 

下面講解一個點擊按鈕是輸入框聚焦的示例:

<template>
  <div>
      <input ref="myInp" type="text" placeholder="這是一個輸入框" v-if="isShow">
      <button v-else @click="btn">點擊我進行搜索</button>
  </div>
</template>
 
<script>
 
// 獲取到輸入框
// 輸入框調(diào)用事件方法focus()達到聚焦行為
export default {
    data(){
        return {
            isShow: false
        }
    },
    methods: {
        btn(){
            this.isShow = true;
 
            this.$refs.myInp.focus(); // 沒有效果
            
            // 原因: data變化更新DOM是異步的
            // 輸入框還沒有掛載到真實DOM上
            // 解決:
            // this.$nextTick(() => {
            //     this.$refs.myInp.focus()
            // })
        }
        //async btn(){  
        //    this.isShow = true;
        //    
        //    // 擴展: await取代回調(diào)函數(shù)
        //    // $nextTick()原地返回Promise對象
        //    await this.$nextTick()
        //    this.$refs.myInp.focus()
        //}
    },
     //擴展
    updated(){  
     // this.$refs.myInp.focus()
    
    }
}
</script>

 直接在methods獲取DOM調(diào)用聚焦方法是沒有效果的,更改之后的文本是需要 dom 更新之后才會實現(xiàn)的,就像我們把將要打印輸出的代碼放在 setTimeout(fn, 0) 中,這時候用this.$nextTick就能合理解決此問題,如果我們想進頁面就處于聚焦狀態(tài)的話就可以使用updated生命周期函數(shù),調(diào)用時,組件DOM已經(jīng)更新,所以可以執(zhí)行依賴于DOM的操作

到此這篇關(guān)于使用this.$nextTick()獲取不到數(shù)據(jù)更新后的this.$refs.xxx.及場景分析的文章就介紹到這了,更多相關(guān)this.$nextTick()獲取不到數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于vue.js組件數(shù)據(jù)流的問題

    關(guān)于vue.js組件數(shù)據(jù)流的問題

    本篇文章主要介紹了關(guān)于vue.js組件數(shù)據(jù)流的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Vue.js事件處理器與表單控件綁定詳解

    Vue.js事件處理器與表單控件綁定詳解

    這篇文章主要為大家詳細介紹了Vue.js事件處理器與表單控件綁定詳解的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • vue router返回到指定的路由的場景分析

    vue router返回到指定的路由的場景分析

    這篇文章主要介紹了vue router返回到指定的路由的場景分析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • php+vue3實現(xiàn)點選驗證碼功能

    php+vue3實現(xiàn)點選驗證碼功能

    這篇文章主要介紹了php+vue3實現(xiàn)點選驗證碼,本文通過實例代碼給大家介紹的詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • vue.js路由跳轉(zhuǎn)詳解

    vue.js路由跳轉(zhuǎn)詳解

    這篇文章主要為大家詳細介紹了vue.js路由跳轉(zhuǎn)的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • vue父組件傳值子組件報錯Avoid?mutating?a?prop?directly解決

    vue父組件傳值子組件報錯Avoid?mutating?a?prop?directly解決

    這篇文章主要為大家介紹了vue父組件傳值子組件報錯Avoid?mutating?a?prop?directly解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • vue通過url方式展示PDF的幾種方法

    vue通過url方式展示PDF的幾種方法

    小編最近接手的項目中有個需求,前端顯示后端返回的PDF格式的文件,下面這篇文章主要給大家介紹了關(guān)于vue通過url方式展示PDF的幾種方法,需要的朋友可以參考下
    2023-01-01
  • 詳解vue axios二次封裝

    詳解vue axios二次封裝

    這篇文章給大家分享了vue axios二次封裝的相關(guān)知識點等內(nèi)容以及實例代碼,有興趣的朋友可以參考學習下。
    2018-07-07
  • vue實現(xiàn)自定義組件掛載原型上

    vue實現(xiàn)自定義組件掛載原型上

    這篇文章主要介紹了vue實現(xiàn)自定義組件掛載原型上方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • VUE項目中引入vue-router的詳細過程

    VUE項目中引入vue-router的詳細過程

    vue-router 也叫 vue 路由,根據(jù)不同的路徑,來執(zhí)行不同的組件,這篇文章主要介紹了VUE項目中引入vue-router,需要的朋友可以參考下
    2023-05-05

最新評論