$nextTick

在vue中修改數(shù)據(jù)不會(huì)導(dǎo)致DOM立即更新,因此修改數(shù)據(jù)后無法拿到最新的DOM,從而無法進(jìn)行相應(yīng)的DOM操作。
這時(shí)就需要$nextTick() 在下次 DOM 更新循環(huán)結(jié)束之后執(zhí)行延遲回調(diào)。在修改數(shù)據(jù)之后立即使用這個(gè)方法,獲取更新后的 DOM。

如果你在數(shù)據(jù)改變之后的操作跟改變之后的DOM有關(guān),那么就應(yīng)該使用Vue.nextTick()

如點(diǎn)擊下方的小圖標(biāo)切換input的type類型后,獲取密碼框DOM并讓其聚焦

image.png

下面的代碼無法獲取最新的DOM,所以不起作用

  methods: {
    toggleType () {
      if (this.passwordType == 'password') {
        this.passwordType = ''
      } else {
        this.passwordType = 'password'
      }

      this.$refs.password.focus()
      
    }
  }

修改上面的代碼,將DOM操作放在$nextTick()的回調(diào)函數(shù)中,問題得到解決

       this.$nextTick(() => {
        this.$refs.password.focus()
      })
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容