React 屬性和狀態的一些總結


 

一、屬性

  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>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM