• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 4年前 (2022-01-04) 18次浏览 已收录 0个评论

一、属性

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> <html>  <head>   <meta http-equiv='Content-type' content='text/html; charset=utf-8'>   <title>daomul's example</title>   <link rel="stylesheet" href="../shared/css/base.css" />  </head>  <body>   <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=<strong style="color:transparent">来源gaodai#ma#com搞@代~码网</strong>{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>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:浅谈React 属性和状态的一些总结

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址