一、屬性
1、第一種使用方法:鍵值對
<ClaaNameA name = “Tom” />
<ClaaNameA name = {Tom} />
<ClaaNameA name = {“Tom”} />
<ClaaNameA name = {[1,2,3]} />//數組
<ClaaNameA name = {FunctionNAme} /> //定義一個函數
2、第二種方法:三個點的展開對象形式
var props = {
one :”123”,
tow :321
}
<ClassNameB {…props} />
增加三個引號相當於這里面拿到兩個屬性了(one和two)
3、setProps形式:通過組件更新屬性,不能在組件內部中修改屬性的,因為會違背組件設計原則(盡量避免)
var instance =React.render(<ClassNameC ><ClaasNameC/>,document.body);
instance.setProps({name:”Tom" });
二、狀態:事物所處的狀況,由事物自行處理不斷變化/事物的私有屬性
getInitialState:初始化每個實例特有的狀態
setState:更新組件狀態
setState會觸發diff算法:判斷state和頁面結果的區別,是否需要更新
三、狀態和屬性對比
狀態和屬性都會觸發render更新,都是純JS對象
狀態:是和自己相關的,既不受父組件也不受子組件影響
屬性:本身是不能自己去修改的,只能從父組件獲取屬性,父組件也能修改它的屬性
根本的區別:組件在運行時需要去修改維護的就是狀態
四、簡單的demo熟悉一下:
1 <!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> 10 <div id="container"> 11 12 </div> 13 14 <script src="../shared/thirdparty/es5-shim.min.js"></script> 15 <script src="../shared/thirdparty/es5-sham.min.js"></script> 16 <script src="../shared/thirdparty/console-polyfill.js"></script> 17 <script src="../../build/react.js"></script> 18 <script src="../../build/JSXTransformer.js"></script> 19 <script type="text/jsx"> 20 21 //內容組件 22 var Content = React.createClass({ 23 getInitialState:function(){ 24 return { 25 inputText:'', 26 }; 27 }, 28 handleChange:function(event){ 29 this.setState({inputText:event.target.value}); 30 }, 31 handleClick:function(){ 32 console.log("props name is " + this.props.selectName + " \n and inputText is " + this.state.inputText); 33 }, 34 render:function(){ 35 36 return <div> 37 <textarea onChange = {this.handleChange} placeholder = "please input something!"></textarea> 38 <button onClick = {this.handleClick}>sumbit</button> 39 </div>; 40 }, 41 }); 42 43 //評論組件 44 var Comment = React.createClass({ 45 getInitialState:function(){ 46 return { 47 names:["Tom","Axiba","daomul"], 48 selectName:'', 49 }; 50 }, 51 handleSelect:function(){ 52 this.setState( 53 {selectName : event.target.value} 54 ); 55 }, 56 render:function(){ 57 var options = []; 58 //往options中添加子option 59 for (var option in this.state.names) { 60 options.push(<option value={this.state.names[option]}> {this.state.names[option]} </option>) 61 }; 62 return <div> 63 <Content selectName = {this.state.selectName}> 64 </Content> 65 <select onChange = {this.handleSelect}> 66 {options} 67 </select> 68 </div>; 69 }, 70 }); 71 72 //start render 73 React.render(<Comment></Comment>,document.body); 74 </script> 75 </body> 76 </html>