中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3中ref綁定dom或組件失敗的原因是什么及怎么解決

發布時間:2023-04-19 16:33:35 來源:億速云 閱讀:162 作者:iii 欄目:開發技術

本篇內容介紹了“vue3中ref綁定dom或組件失敗的原因是什么及怎么解決”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

    vue3 ref綁定dom或者組件失敗原因分析

    場景描述

    在vue3中經常用到使用ref綁定組件或者dom元素的情況,很多時候,明明使用ref綁定了相關組件,但是經常ref綁定失敗的情況。

    ref綁定失敗情況舉例

    ref綁定失敗的絕大多數情況是,在ref和組件綁定的時候,該組件還未渲染,所以綁定失敗。

    或者組件剛開始未渲染,ref未綁定,當組件開始渲染,ref也開始綁定,但是ref和組件并未綁定完成,這個時候使用組件相關的方法就會出現問題。

    • ref綁定的組件使用了v-if,或者他的父組件使用了v-if導致頁面開始渲染的時候,這些組件并沒有渲染,所以綁定失敗。

    • element-plus中有很多 dialog彈窗等組件,這些組件開始是隱藏的,只有用戶點擊了按鈕才展示,所以很多時候是在用戶點擊按鈕的時候,ref才開始和組件綁定,這個時候綁定還未完成,我們通過ref的變量使用組件的方法,就會出現Uncaught TypeError: Cannot read properties of null (reading 'setCheckedNodes')的錯誤

    vue3中ref綁定dom或組件失敗的原因是什么及怎么解決

    解決方案

    使用vue3的nextTick方法,讓調用ref組件方法的邏輯放到下一個時間片執行即可。(推薦

    function addFilterPropertyRule(row) {
    
        let ruleParamObj = JSON.parse(row.hardwareParam)
        if (ruleParamObj) {
            makePropertityTree(ruleParamObj, treeData)
        }
        addOrEditRuleVisible.value = true
        currentRuleItem = row
        if (row.ruleJson) {
            nextTick(() => {
                treeRef.value.setCheckedNodes(JSON.parse(row.ruleJson), false)
            })
        }
    }

    使用一個延時定時器,讓調用ref組件方法的邏輯等一會再執行。(不推薦) 

    vue3組合式API的v-for及ref綁定DOM

    組合式 API 模板引用在 v-for 內部使用時沒有特殊處理。需要綁定函數自定義處理。

    <template>
      <div v-for="(item, i) in list" :ref="el => { if (el) divs[i] = el }">
        {{ item }}
      </div>
    </template>
     
    <script>
      import { ref, reactive, onBeforeUpdate } from 'vue'
     
      export default {
        setup() {
          const list = reactive([1, 2, 3])
          const divs = ref([])
     
          // 確保在每次更新之前重置ref
          onBeforeUpdate(() => {
            divs.value = []
          })
     
          return {
            list,
            divs
          }
        }
      }
    </script>
    • Ref

    <template> 
      <div ref="root">This is a root element</div>
    </template>
     
    <script>
      import { ref, onMounted } from 'vue'
     
      export default {
        setup() {
          const root = ref(null)
     
          onMounted(() => {
            // DOM 元素將在初始渲染后分配給 ref
            console.log(root.value) // <div>This is a root element</div>
          })
     
          return {
            root
          }
        }
      }
    </script>

    “vue3中ref綁定dom或組件失敗的原因是什么及怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    五家渠市| 常州市| 沙坪坝区| 萨嘎县| 安达市| 儋州市| 永年县| 清原| 江津市| 茌平县| 景德镇市| 喀什市| 竹山县| 绥中县| 吴堡县| 安阳县| 台安县| 紫金县| 灵宝市| 宁阳县| 青岛市| 南召县| 张掖市| 保亭| 乌兰浩特市| 海口市| 巍山| 晋城| 淳安县| 库伦旗| 昌平区| 体育| 灵寿县| 龙陵县| 莒南县| 乌拉特前旗| 乌鲁木齐县| 棋牌| 荆门市| 正定县| 嵩明县|