源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

浅谈React 属性和状态的一些总结

  • 时间:2022-10-27 16:43 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:浅谈React 属性和状态的一些总结
[b]一、属性[/b] [b]1、第一种使用方法:键值对 [/b] <ClaaNameA name = “Tom” /> <ClaaNameA name = {Tom} /> <ClaaNameA name = {“Tom”} /> <ClaaNameA name = {[1,2,3]} />//数组 <ClaaNameA name = {FunctionNAme} /> //定义一个函数 [b]2、第二种方法:三个点的展开对象形式 [/b]
var props = {

one :”123”,

tow :321

 }

<ClassNameB {…props} />
增加三个引号相当于这里面拿到两个属性了(one和two) [b]3、setProps形式:通过组件更新属性,不能在组件内部中修改属性的,因为会违背组件设计原则(尽量避免) [/b]
var instance =React.render(<ClassNameC ><ClaasNameC/>,document.body);

instance.setProps({name:”Tom" });
[b]二、状态:事物所处的状况,由事物自行处理不断变化/事物的私有属性[/b] getInitialState:初始化每个实例特有的状态 setState:更新组件状态 setState会触发diff算法:判断state和页面结果的区别,是否需要更新 [b]三、状态和属性对比[/b] 状态和属性都会触发render更新,都是纯JS对象 状态:是和自己相关的,既不受父组件也不受子组件影响 属性:本身是不能自己去修改的,只能从父组件获取属性,父组件也能修改它的属性 根本的区别:组件在运行时需要去修改维护的就是状态 [b]四、简单的demo熟悉一下:[/b]
<!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 属性和状态的一些总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部