v-if案例解析(element-ui form-item表單無法驗證問題剖析 )

来源:https://www.cnblogs.com/teamblog/archive/2018/08/31/9566415.html
-Advertisement-
Play Games

1、本文根據問題,講述大致 Vue虛擬Dom Diff 思路、數據響應式機制相關,源碼版本 Vue.js v2.5.17-beta.0 2、知識點:vue virtual dom diff、 observe 、 watch、render ,各知識點暫不深入剖析   3、閱讀本文,讀... ...


fire

讀在最前面:

  1、此文章銜接Vue 虛擬Dom 及 部分生命周期初探,相關整體知識點請先閱讀後再繼續本文閱讀


問:當v-if為true時,會重新渲染相關dom節點嗎?

<child v-if="true"></child>

點擊查看涉案代碼

點擊圖中【切換】字樣 查看效果,如下圖:

流程分析:

1、首先我們按代碼畫出初始化vnode和點擊切換後的vnode,進行第一次 對比,如下圖

 說明:頭頭比較的時候,節點沒有任何變化,所以直接不動即可,如果a的相關屬性有變動,則直接更新即可

 

 2、第一次迴圈結束後,我們a和a已經處理過了,所以下次不再進行處理,第二次對比開始,如下圖

 

 說明:第二輪結束的時候已經遍歷完成2組節點配對

 

 3、第三次對比開始,如下圖

 

 說明:到這裡,已經看到了為什麼有v-if 為 ture,但節點還是重新渲染了,其他節點類推

 

回到element-ui form-item 無法驗證問題也是同理

組件節點被覆用了,所以驗證也就自然失效了

 

備註:  

  1、virtual-dom-diff 會有dom節點復用問題,針對有狀態依賴關係的儘量加key作為區分,這樣能避免不相關節點因為沒有key而出現異常

  2、在存在大量標簽的情況下,儘量不要加深dom層級,塊級v-if可以用template包裹,這樣可以避免不必要的錯誤(沒加key)dom節點復用了問題

 

 by:海豚灣-豐

   


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 遍歷應該是各種語言中常會用到的操作了,實現的方法也很多,例如使用for、while等迴圈語句就可以很輕鬆的做到對數組或對象的遍歷,今天想講的不是它們,而是簡單方便的遍歷方法。 大致的整理了一下,經常用到的大概有Jquery的$.each、$.map、each()、map()、get()、toArra ...
  • ``` 全選和全不選以及反選 全選 編號姓名年齡 1張三12 2李四22 3王五13 4馬六14 ... ...
  • 疑問:為什麼this.style.backgroundColor = oldColor中的this不能用$("tbody tr")[i]代替?? ...
  • angularjs指針(directive)中的作用域(scope)的隔離作用域學習研究 ...
  • 路由,其實就是指向的意思,當我點擊頁面上的home按鈕時,頁面中就要顯示home的內容,如果點擊頁面上的about 按鈕,頁面中就要顯示about 的內容。Home按鈕 => home 內容, about按鈕 => about 內容,也可以說是一種映射. 所以在頁面上有兩個部分,一個是點擊部分,一個 ...
  • 經過對前端技術的學習,感觸良多,雖然之前也接觸過前端的知識,但是沒有進行系統的學習過,在大三上學期學過h5和簡單的css,老師也沒有深度講解,知識也沒有形成體系,經過一段時間的學習,有以下感觸與大家分享: 整個前端知識就像一座房子,而Html是磚,建一個網頁,裡面有很多磚(html裡面最重要的就是標 ...
  • Vue2.0 詳細教程 —— 搭建Vue腳手架(vue-cli) ...
  • 按照顯示元素分類: 行內元素(lnline-element):元素的高度,行高,頂底邊距由元素所包含的圖片或文字所決定,不可改變;其寬度為內容文字或圖片的寬度所決定,而其左右邊距可人為設置。 行內元素的水平方向的padding-left,padding-right,margin-left,margi ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...