自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

受控和非受控表單 | 不受控制的東西,你非要往家領(lǐng)?

開發(fā) 前端
規(guī)范化的方式依然是借助 ref 來實(shí)現(xiàn),只不過這個(gè) ref 是由 React 的內(nèi)置方法 createRef() 調(diào)用后生成的,在獲取時(shí),直接調(diào)用生成的 ref 就可以了。

[[425903]]

本文轉(zhuǎn)載自微信公眾號(hào)「勾勾的前端世界」,作者西嶺。轉(zhuǎn)載本文請(qǐng)聯(lián)系勾勾的前端世界公眾號(hào)。

常用的受控表單示例

受控的下拉列表

  1. import React, { Component } from 'react' 
  2.  
  3. export class Tables extends Component { 
  4.  
  5.   state = { 
  6.     subject: "HTML" 
  7.   } 
  8.  
  9.   render() { 
  10.     return ( 
  11.       <div> 
  12.         <p>{this.state.subject}</p> 
  13.         <select name="" id="" value={this.state.subject} 
  14.           onChange={ 
  15.             (ev) => this.setState( 
  16.               { subject: ev.target.value } 
  17.             ) 
  18.           }> 
  19.           <option value="JS">JS</option
  20.           <option value="HTML">HTML</option
  21.           <option value="CSS">CSS</option
  22.         </select
  23.  
  24.       </div> 
  25.     ) 
  26.   } 
  27.  
  28. export default Tables 

受控單選框

  1. import React, { Component } from 'react' 
  2.  
  3. export class Tables extends Component { 
  4.  
  5.   state = { 
  6.     sex: "男" 
  7.   } 
  8.  
  9.   render() { 
  10.     return ( 
  11.       <div> 
  12.         <p>{this.state.sex}</p> 
  13.         <input type="radio" name="sex" id="" value="男" 
  14.           onChange={ 
  15.             (ev) => this.setState({ sex: ev.target.value }) 
  16.           } /> 男 
  17.         <input type="radio" name="sex" id="" value="女" 
  18.           onChange={ 
  19.             (ev) => this.setState({ sex: ev.target.value }) 
  20.           } /> 女 
  21.         <input type="radio" name="sex" id="" value="妖" 
  22.           onChange={ 
  23.             (ev) => this.setState({ sex: ev.target.value }) 
  24.           } /> 妖 
  25.       </div> 
  26.     ) 
  27.   } 
  28.  
  29. export default Tables 

受控復(fù)選框

  1. import React, { Component } from 'react' 
  2.  
  3. export class Tables extends Component { 
  4.  
  5.   // 模擬數(shù)據(jù)源 
  6.   Datas = [ 
  7.     {id:1,title:'HTML',isChecked:false}, 
  8.     {id:2,title:'JS',isChecked:true}, 
  9.     {id:3,title:'CSS',isChecked:false}, 
  10.   ] 
  11.  
  12.   checks = (index,ev)=>{ 
  13.     // console.log(ev.target.checked) 
  14.     // console.log(index
  15.  
  16.     this.Datas[index].isChecked = ev.target.checked 
  17.   } 
  18.  
  19.   render() { 
  20.     return ( 
  21.       <div> 
  22.         <h2>復(fù)選框</h2> 
  23.         { 
  24.           this.Datas.map((data,index)=>{ 
  25.             return ( 
  26.               <label key={data.id}> 
  27.                 {/* 使用 onChange 事件綁定,傳遞下標(biāo)及事件對(duì)象,在處理函數(shù)中進(jìn)行狀態(tài)修改 */} 
  28.                 <input type="checkbox" defaultChecked={data.isChecked} onChange={(ev)=>{this.checks(index,ev)}} /> {data.title}  
  29.               </label> 
  30.             ) 
  31.           }) 
  32.         } 
  33.  
  34.         <button onClick={()=>console.log(this.Datas)} >展示多選框內(nèi)容數(shù)據(jù)</button> 
  35.       </div> 
  36.     ) 
  37.   } 
  38.  
  39. export default Tables 

非受控表單

在大多數(shù)情況下,我們推薦使用 受控表單 來處理表單數(shù)據(jù)。

在一個(gè)受控組件中,表單數(shù)據(jù)是由 React 組件來管理的。另一種替代方案是使用非受控表單,這時(shí)表單數(shù)據(jù)將交由 DOM 節(jié)點(diǎn)來處理。

受控表單需要為每個(gè)狀態(tài)更新都編寫數(shù)據(jù)處理函數(shù),而使用非受控表單,你可以使用 ref 來從 DOM 節(jié)點(diǎn)中獲取表單數(shù)據(jù)。

  1. import React, { Component } from 'react' 
  2.  
  3. export class Tables extends Component { 
  4.  
  5.  
  6.   gets = ()=>{ 
  7.     console.log(this.refs.users.value) 
  8.   } 
  9.  
  10.   render() { 
  11.     return ( 
  12.       <div> 
  13.         <input type="text" ref='users'/> 
  14.         <button onClick={()=>this.gets()}>獲取</button> 
  15.       </div> 
  16.     ) 
  17.   } 
  18.  
  19. export default Tables 

但是,這樣的用法會(huì)在瀏覽器中看到一個(gè)警告型的報(bào)錯(cuò)信息,原因也很簡單,在新版的 React 中,默認(rèn)啟用了嚴(yán)格模式。

Warning: A string ref, "users", has been found within a strict mode tree.

我們需要在入口的 index.js 中,將嚴(yán)格模式的代碼刪除,如下:

  1. ReactDOM.render( 
  2.  <React.StrictMode> 
  3.    <App /> 
  4.  </React.StrictMode>, 
  5.  document.getElementById('root'
  6. ); 

改完之后就是這個(gè)鬼樣子了,錯(cuò)誤提示就消失了:

  1. ReactDOM.render( 
  2.     <App />, 
  3.   document.getElementById('root'
  4. ); 

規(guī)范化寫法

但是,這樣的方式并不好,別問為什么,就是不好,我們建議使用下面的方式:

  1. import React, { Component } from 'react' 
  2.  
  3. export class Tables extends Component { 
  4.   constructor (){ 
  5.     super() 
  6.     this.myref = React.createRef() 
  7.   } 
  8.  
  9.   gets = ()=>{ 
  10.     console.log(this.myref.current.value) 
  11.   } 
  12.  
  13.   render() { 
  14.     return ( 
  15.       <div> 
  16.         <input type="text" ref={this.myref} /> 
  17.         <button onClick={()=>this.gets()}>獲取</button> 
  18.       </div> 
  19.     ) 
  20.   } 
  21.  
  22. export default Tables 

規(guī)范化的方式依然是借助 ref 來實(shí)現(xiàn),只不過這個(gè) ref 是由 React 的內(nèi)置方法 createRef() 調(diào)用后生成的,在獲取時(shí),直接調(diào)用生成的 ref 就可以了。

但是,需要注意,不論哪種方式,知道就行了,非受控表單,能不用就不要用,為啥啊?不受控制的東西,你也敢往家里領(lǐng)?

又但是,正因?yàn)榉鞘芸乇韱螌⒄鎸?shí)數(shù)據(jù)儲(chǔ)存在 DOM 節(jié)點(diǎn)中,所以在使用非受控表單時(shí),有時(shí)候反而更容易同時(shí)集成 React 和非 React 代碼。如果你不介意代碼美觀性,并且希望快速編寫代碼,使用非受控組件往往可以減少你的代碼量。否則,你應(yīng)該使用受控組件。

總結(jié)

在應(yīng)用頁面中,與用戶交互的基本都是在表單中呈現(xiàn)的。根據(jù) React 框架的設(shè)計(jì)理念,對(duì)于表單的渲染工作,肯定由框架負(fù)責(zé)的,而表單數(shù)據(jù)的交互必然需要收到框架的控制和依賴,受控表單才是我們最應(yīng)該使用的表單方式,但是非受控表單明顯代碼更多,非受控表單是為了在特殊情況下獲取 Dom 而存在的,官方也不建議使用,即便非受控表單看起來更好用。

至此,React 基本語法部分,算是告一段落,這一路走來,我淚眼婆娑,我披荊斬棘,我彷徨迷惘,我真不容易……

雖然不容易,但是,我那么好看,怎么可能這么結(jié)束了呢,不寫個(gè)案例也太不像話了!

 

責(zé)任編輯:武曉燕 來源: 勾勾的前端世界
相關(guān)推薦

2022-07-06 08:29:12

antdInput 組件

2021-07-09 08:33:35

React組件受控

2024-08-09 12:47:12

2021-03-18 08:00:55

組件Hooks React

2020-10-21 08:38:47

React源碼

2021-12-13 14:37:37

React組件前端

2023-12-12 13:50:00

代碼業(yè)務(wù)狀態(tài)

2011-04-02 13:44:08

2023-10-12 10:10:00

微軟Windows

2021-09-14 18:33:39

React 數(shù)據(jù)交互

2010-05-26 15:17:24

IPv6組播源

2010-01-08 14:35:58

2015-06-26 17:09:10

數(shù)據(jù)中心

2009-08-31 16:48:02

C#實(shí)現(xiàn)IDispos

2022-05-20 08:35:59

useEffect函數(shù)式組件React

2022-07-11 11:14:47

強(qiáng)化學(xué)習(xí)AI基于模型

2009-01-18 09:16:00

2014-08-12 10:32:30

2017-01-22 15:09:08

架構(gòu)閉環(huán)演進(jìn)

2014-08-20 10:14:14

程序員
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)