成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

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

[[425903]]

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

常用的受控表單示例

受控的下拉列表

  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 

受控復選框

  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>復選框</h2> 
  23.         { 
  24.           this.Datas.map((data,index)=>{ 
  25.             return ( 
  26.               <label key={data.id}> 
  27.                 {/* 使用 onChange 事件綁定,傳遞下標及事件對象,在處理函數(shù)中進行狀態(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ù)。

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

受控表單需要為每個狀態(tài)更新都編寫數(shù)據(jù)處理函數(shù),而使用非受控表單,你可以使用 ref 來從 DOM 節(jié)點中獲取表單數(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 

但是,這樣的用法會在瀏覽器中看到一個警告型的報錯信息,原因也很簡單,在新版的 React 中,默認啟用了嚴格模式。

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

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

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

改完之后就是這個鬼樣子了,錯誤提示就消失了:

  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 來實現(xiàn),只不過這個 ref 是由 React 的內(nèi)置方法 createRef() 調(diào)用后生成的,在獲取時,直接調(diào)用生成的 ref 就可以了。

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

又但是,正因為非受控表單將真實數(shù)據(jù)儲存在 DOM 節(jié)點中,所以在使用非受控表單時,有時候反而更容易同時集成 React 和非 React 代碼。如果你不介意代碼美觀性,并且希望快速編寫代碼,使用非受控組件往往可以減少你的代碼量。否則,你應該使用受控組件。

總結(jié)

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

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

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

 

責任編輯:武曉燕 來源: 勾勾的前端世界
相關(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組件前端

2011-04-02 13:44:08

2023-12-12 13:50:00

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

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#實現(xiàn)IDispos

2022-05-20 08:35:59

useEffect函數(shù)式組件React

2022-07-11 11:14:47

強化學習AI基于模型

2014-08-12 10:32:30

2009-01-18 09:16:00

2017-01-22 15:09:08

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

2014-08-20 10:14:14

程序員
點贊
收藏

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

主站蜘蛛池模板: 精品国产18久久久久久二百 | 中文字幕在线视频观看 | 日韩免费一区 | 亚洲精品国产偷自在线观看 | 日本精品一区二区三区视频 | 久久久九九九九 | 国产精品国产成人国产三级 | 成人免费精品视频 | 精品国产免费人成在线观看 | 午夜欧美a级理论片915影院 | 国产一区二区三区欧美 | 成人深夜福利 | 亚洲欧洲精品一区 | 天天色影视综合 | 欧美国产精品一区二区三区 | 日韩成人av在线 | 久久爱一区 | 精国产品一区二区三区四季综 | 欧美成人在线免费 | 久草视频观看 | 欧美日韩亚洲系列 | 免费在线成人 | 好姑娘影视在线观看高清 | 国产欧美日韩精品一区 | 91精品国产综合久久久久久蜜臀 | 精品中文字幕一区二区三区 | 一区二区精品视频 | 日韩电影中文字幕 | 日本午夜在线视频 | 精品毛片在线观看 | 成人精品国产 | 97国产精品视频人人做人人爱 | 成人激情视频在线观看 | 91人人看 | 在线观看成人 | 国产精品视频一二三区 | 久久99蜜桃综合影院免费观看 | 国产男女猛烈无遮掩视频免费网站 | 国产精品一区二区三区四区 | 午夜影院在线观看 | 亚洲不卡一 |