摘要:根據虛擬的算法,只要改變節點的類型就能促使在的時候重新創建虛擬。不過這個效果依賴于虛擬算法。如果使用時候出現什么副作用,鄙人概不負責。此技巧在寫文章時正處于的版本
我們知道 React 的標準模式是單向數據流,而其表單項通常需要監聽 onChange 事件,然后通過改變外部的 value 來回寫表單項的 value,譬如如下 input
class App extends React.Component { constructor( props ) { super( props ); this.state = { inputValue: "default" } this.inputChangeHandler = ( e )=>{ this.setState( { inputValue: e.target.value } ); } } render() { return () } }
如果表單有很多表單項,那么這種標準的做法需要你寫很多個 state 的屬性和很多個 onChange 監聽函數,這是一個體力活兒。但是一般的表單應用其實不需要實時監控表單項的用戶輸入,用 defaultValue 足以,在表單項目 onBlur 或者最后提交的時候一次驗證獲取用戶輸入即可,譬如:
class App extends React.Component { constructor( props ) { super( props ); this.submit = ( e )=>{ let userInputValue = this.refs.userInput.value; // 1. 驗證 userInputValue // 2. 提交表單 } } render() { return () } }
這樣就可以少寫不少代碼,當然你可以寫一些工具去批量添加所有的 onChange 事件監聽函數和對應的 state 的屬性,譬如 redux-form。(回頭一想,這種寫法在提交時候也需要寫很多獲取用戶輸入的代碼,如果使用第一種正模式,那么提交時候只需要獲取 state 就可以了,不過這里先不討論這些)
對于一個表單而言,通常還需要重置功能(reset),如果是第一種正模式的寫法,我們只要保存一份初始化的默認值,在用戶點擊到了重置后,通過 setState 設回去就行了。但是如果使用第二種 defaultValue 的寫法,那么就沒有辦法了,因為 defaultValue 只在第一次創建虛擬 dom 的時候有作用,如果 dom 不改變你改變 defaultValue 是沒有用的。這個時候該怎么辦呢?
嘿嘿!這個時候我們就可以用到這個奇技淫巧了。既然 defaultValue 是在創建虛擬 dom 的時候有用,那么我們在用戶點擊重置的時候讓 React 重新創建這些表單項的虛擬 dom 不就好了么。根據 React 虛擬 dom diff 的算法,只要改變 dom 節點的類型就能促使在 diff 的時候重新創建虛擬 dom。具體的寫法我們就用代碼來演示下:
class App extends React.Component { constructor( props ) { super( props ); // fieldSetWrapperType 是一個標志位屬性,render 中會根據這個變量的值的不同,渲染不同的元素 this.fieldSetWrapperType = "div"; this.submit = ( e )=>{ let userInputValue = this.refs.userInput.value; // 1. 驗證 userInputValue // 2. 提交表單 } this.reset = ()=>{ // 點擊重置,改變標志位 this.fieldSetWrapperType = this.fieldSetWrapperType === "div" ? "section" : "div"; // 強制刷新這個組件 this.forceUpdate(); } } // 把表單項的渲染抽象到一個方法中,避免重復編碼 renderFieldSet() { return ( ); } render() { return () } }
思路就是在表單項外面包一層元素,每次點擊重置后改變一個變量,再強制刷新這個組件,組件根據這個變量不同的值把這個包裝元素的 type 改變,那么它下面的所有表單項的虛擬 dom 都會被重新創建,達到了重置的目的。不過這個效果依賴于 React 虛擬dom diff 算法。如果以后算法改變了,那么可能就失效了,而且這個寫法是反模式的,我初衷是想在處理巨型表單時候少寫點代碼偷懶用。如果使用時候出現什么副作用,鄙人概不負責。
此技巧在寫文章時 React 正處于 15.4.x 的版本
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/83111.html
摘要:背景介紹入門實例教程起源于的內部項目,因為該公司對市場上所有框架,都不滿意,就決定自己寫一套,用來架設的網站。做出來以后,發現這套東西很好用,就在年月開源了。也就是說,通過鉤子函 react - JSX React 背景介紹 React 入門實例教程 React 起源于 Facebook 的內部項目,因為該公司對市場上所有 JavaScript MVC 框架,都不滿意,就決定自己寫一套...
摘要:但在中會有些不同,包含表單元素的組件將會在中追蹤輸入的值,并且每次調用回調函數時,如會更新,重新渲染組件。在構造函數中調用的目的是什么在被調用之前,子類是不能使用的,在中,子類必須在中調用。將使用單個事件監聽器監聽頂層的所有事件。 已經開源 地址:https://github.com/nanhupatar...關注我們團隊:showImg(https://segmentfault.co...
摘要:的一個突出特點是擁有極速地渲染性能。該功能依靠的就是研發團隊弄出的虛擬機制以及其獨特的算法。在的算法下,在同一位置對比前后節點只要發現不同,就會刪除操作前的節點包括其子節點,替換為操作后的節點。 React的一個突出特點是擁有極速地渲染性能。該功能依靠的就是facebook研發團隊弄出的虛擬dom機制以及其獨特的diff算法。下面簡單解釋一下react虛擬dom機制和diff算法的實現...
摘要:本系列文章將重點分析類似于的這類框架是如何實現的,歡迎大家關注和討論。作為一個極度精簡的庫,函數是屬于本身的。 前言 首先歡迎大家關注我的掘金賬號和Github博客,也算是對我的一點鼓勵,畢竟寫東西沒法獲得變現,能堅持下去也是靠的是自己的熱情和大家的鼓勵。 之前分享過幾篇關于React的文章: React技術內幕: key帶來了什么 React技術內幕: setState的秘密...
閱讀 2340·2021-09-30 09:47
閱讀 2959·2019-08-30 11:05
閱讀 2534·2019-08-29 17:20
閱讀 1921·2019-08-29 13:01
閱讀 1727·2019-08-26 13:39
閱讀 1249·2019-08-26 13:26
閱讀 3210·2019-08-23 18:40
閱讀 1828·2019-08-23 17:09