淺談React 屬性和狀態(tài)的一些總結(jié)
一、屬性
1、第一種使用方法:鍵值對(duì)
<ClaaNameA name = “Tom” />
<ClaaNameA name = {Tom} />
<ClaaNameA name = {“Tom”} />
<ClaaNameA name = {[1,2,3]} />//數(shù)組
<ClaaNameA name = {FunctionNAme} /> //定義一個(gè)函數(shù)
2、第二種方法:三個(gè)點(diǎn)的展開對(duì)象形式
var props = {
one :”123”,
tow :321
}
<ClassNameB {…props} />
增加三個(gè)引號(hào)相當(dāng)于這里面拿到兩個(gè)屬性了(one和two)
3、setProps形式:通過組件更新屬性,不能在組件內(nèi)部中修改屬性的,因?yàn)闀?huì)違背組件設(shè)計(jì)原則(盡量避免)
var instance =React.render(<ClassNameC ><ClaasNameC/>,document.body);
instance.setProps({name:”Tom" });
二、狀態(tài):事物所處的狀況,由事物自行處理不斷變化/事物的私有屬性
getInitialState:初始化每個(gè)實(shí)例特有的狀態(tài)
setState:更新組件狀態(tài)
setState會(huì)觸發(fā)diff算法:判斷state和頁面結(jié)果的區(qū)別,是否需要更新
三、狀態(tài)和屬性對(duì)比
狀態(tài)和屬性都會(huì)觸發(fā)render更新,都是純JS對(duì)象
狀態(tài):是和自己相關(guān)的,既不受父組件也不受子組件影響
屬性:本身是不能自己去修改的,只能從父組件獲取屬性,父組件也能修改它的屬性
根本的區(qū)別:組件在運(yùn)行時(shí)需要去修改維護(hù)的就是狀態(tài)
四、簡(jiǎn)單的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>;
},
});
//評(píng)論組件
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é)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
react實(shí)現(xiàn)無限循環(huán)滾動(dòng)信息
這篇文章主要為大家詳細(xì)介紹了react實(shí)現(xiàn)無限循環(huán)滾動(dòng)信息,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
TS裝飾器bindThis優(yōu)雅實(shí)現(xiàn)React類組件中this綁定
這篇文章主要為大家介紹了TS裝飾器bindThis優(yōu)雅實(shí)現(xiàn)React類組件中this綁定,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
react用Redux中央倉庫實(shí)現(xiàn)一個(gè)todolist
這篇文章主要為大家詳細(xì)介紹了react用Redux中央倉庫實(shí)現(xiàn)一個(gè)todolist,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
適用于React?Native?旋轉(zhuǎn)木馬應(yīng)用程序介紹
這篇文章主要介紹了適用于React?Native?旋轉(zhuǎn)木馬應(yīng)用程序介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
解決react中useState狀態(tài)異步更新的問題
本文主要介紹了react中useState狀態(tài)異步更新的問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07

