国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

淺談React 屬性和狀態的一些總結

2024-05-06 16:32:58
字體:
來源:轉載
供稿:網友

一、屬性

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熟悉一下:

<!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">    //內容組件    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 屬性和狀態的一些總結就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 汉沽区| 扶沟县| 桦甸市| 桑日县| 聂拉木县| 毕节市| 偏关县| 贵德县| 阿克苏市| 搜索| 滦南县| 清镇市| 新巴尔虎右旗| 潍坊市| 盘锦市| 溆浦县| 固安县| 怀集县| 峡江县| 蛟河市| 长葛市| 铁岭县| 梨树县| 安岳县| 牙克石市| 开化县| 沈阳市| 陵川县| 襄垣县| 都江堰市| 亚东县| 济源市| 邻水| 南乐县| 玉屏| 宜章县| 新巴尔虎左旗| 米林县| 开阳县| 石阡县| 拜泉县|