淺談React 屬性和狀態(tài)的一些總結(jié)
一、屬性
1、第一種使用方法:鍵值對
<ClaaNameA name = “Tom” />
<ClaaNameA name = {Tom} />
<ClaaNameA name = {“Tom”} />
<ClaaNameA name = {[1,2,3]} />//數(shù)組
<ClaaNameA name = {FunctionNAme} /> //定義一個函數(shù)
2、第二種方法:三個點(diǎn)的展開對象形式
var props = { one :”123”, tow :321 } <ClassNameB {…props} />
增加三個引號相當(dāng)于這里面拿到兩個屬性了(one和two)
3、setProps形式:通過組件更新屬性,不能在組件內(nèi)部中修改屬性的,因?yàn)闀`背組件設(shè)計(jì)原則(盡量避免)
var instance =React.render(<ClassNameC ><ClaasNameC/>,document.body); instance.setProps({name:”Tom" });
二、狀態(tài):事物所處的狀況,由事物自行處理不斷變化/事物的私有屬性
getInitialState:初始化每個實(shí)例特有的狀態(tài)
setState:更新組件狀態(tài)
setState會觸發(fā)diff算法:判斷state和頁面結(jié)果的區(qū)別,是否需要更新
三、狀態(tài)和屬性對比
狀態(tài)和屬性都會觸發(fā)render更新,都是純JS對象
狀態(tài):是和自己相關(guān)的,既不受父組件也不受子組件影響
屬性:本身是不能自己去修改的,只能從父組件獲取屬性,父組件也能修改它的屬性
根本的區(qū)別:組件在運(yùn)行時需要去修改維護(hù)的就是狀態(tài)
四、簡單的demo熟悉一下:
<!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv='Content-type' content='text/html; charset=utf-8'> 5 <title>daomul's example</title> 6 <link rel="stylesheet" href="../shared/css/base.css" /> 7 </head> 8 <body> 9 <h1>Text demo</h1> <div id="container"> </div> <script src="../shared/thirdparty/es5-shim.min.js"></script> <script src="../shared/thirdparty/es5-sham.min.js"></script> <script src="../shared/thirdparty/console-polyfill.js"></script> <script src="../../build/react.js"></script> <script src="../../build/JSXTransformer.js"></script> <script type="text/jsx"> //內(nèi)容組件 var Content = React.createClass({ getInitialState:function(){ return { inputText:'', }; }, handleChange:function(event){ this.setState({inputText:event.target.value}); }, handleClick:function(){ console.log("props name is " + this.props.selectName + " \n and inputText is " + this.state.inputText); }, render:function(){ return <div> <textarea onChange = {this.handleChange} placeholder = "please input something!"></textarea> <button onClick = {this.handleClick}>sumbit</button> </div>; }, }); //評論組件 var Comment = React.createClass({ getInitialState:function(){ return { names:["Tom","Axiba","daomul"], selectName:'', }; }, handleSelect:function(){ this.setState( {selectName : event.target.value} ); }, render:function(){ var options = []; //往options中添加子option for (var option in this.state.names) { options.push(<option value={this.state.names[option]}> {this.state.names[option]} </option>) }; return <div> <Content selectName = {this.state.selectName}> </Content> <select onChange = {this.handleSelect}> {options} </select> </div>; }, }); //start render React.render(<Comment></Comment>,document.body); </script> </body> </html>
以上這篇淺談React 屬性和狀態(tài)的一些總結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決React?hook?'useState'?cannot?be?called?in?
這篇文章主要為大家介紹了React?hook?'useState'?cannot?be?called?in?a?class?component報(bào)錯解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12React?中如何將CSS?visibility?屬性設(shè)置為?hidden
這篇文章主要介紹了React中如何將CSS?visibility屬性設(shè)置為?hidden,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05React 無狀態(tài)組件(Stateless Component) 與高階組件
這篇文章主要介紹了React 無狀態(tài)組件(Stateless Component) 與高階組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08