1. 运行中可以使用的函数
      componentWillReceiveProps:父组件修改属性触发,可以修改新属性,修改状态。字面意思,组件将要接收属性,这个函数触发的时机就是组件的属性将要发生改变的时候,但是需要注意的是,他是在组件将要改变之前触发,比如说父组件修改了子组件的属性,那么在修改真正发生之前,会触发这个函数,也就说,给开发者一个机会去处理这个属性,开发者可以对比新属性和旧属性,并修改属性和状态,这样,我们就可以在属性真正的被传送到组件之前,对他进行处理,有可能对应的更改一些状态,有可能是修改属性本身。

      shouldComponentUpdate:返回false会阻止render调用。英文意思是组件是否需要更新,也就是react会询问开发者,组件是否需要更新,有的时候,状态发生变化,组件可能不需要更新,只是更新一些数据,不需要更新显示出来的内容,这个时候,就需要这个函数返回false,运行中后面的三个函数都是和render相关的,如果这个函数返回发false,就会直接中断这个流程,后面的三个函数,都不会执行。这里要注意,大部分时候,我们是不需要使用这个函数的,只有在你真正的找到项目的瓶颈之后,再根据需要去修改,因为对这个函数使用不当的话会导致很多无法预料的问题。

      componentWillUpdate:不能修改属性和状态。是在render之前执行

      render:只能访问this.props和this.state,只有一个顶层组件,不允许修改状态和dom输出。

      componentDidUpdate:可以修改dom

    2. 运行中触发顺序。
      这个例子是input输入什么,页面内容就会变成hello什么,出事是hello World
      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>测试</title>
      </head>
      <body>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/react.min.js"></script>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/JSXTransformer.js"></script>
      <script type="text/jsx">
      var style={
      color:"red",
      border:"1px solid #f99",
      width:"200px",
      height:"50px"
      };
      var HelloWorld= React.createClass({
      componentWillReceiveProps:function(){},
      shouldComponentUpdate:function(){return true;},//得返回一个true,否则报错
      componentWillUpdate:function(){},
      render:function(){
      return <p>Hello,{this.props.name ? this.props.name : "World"}</p>;
      },
      componentDidUpdate:function(){},
      });
      var HelloUniverse=React.createClass({
      getInitialState:function(){
      return {name:""};
      },
      handleChange:function(event){
      //用来响应input的输入事件
      this.setState({name:event.target.value});
      },
      render:function(){
      return <div>
      <HelloWorld name={this.state.name
      //这里引用了HelloWorld的组件,所以HelloUniverse是他的子组件
      }></HelloWorld>
      <br />
      <input type="text" onChange={this.handleChange} />
      </div>
      },
      });
      React.render(<div style={style}><HelloUniverse></HelloUniverse></div>,document.body)
      // 写为React.render(<div style={style}><HelloWord></HelloWorld></div>,document.body)看看效果
      </script>
      </body>
      </html>

      改一下代码,查看输出属性的顺序。

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>测试触发顺序,不输入不会触发五个函数,只会触发render</title>
      </head>
      <body>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/react.min.js"></script>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/JSXTransformer.js"></script>
      <script type="text/jsx">
      var style={
      color:"red",
      border:"1px solid #f99",
      width:"200px",
      height:"50px"
      };
      var HelloWorld= React.createClass({
      componentWillReceiveProps:function(){
      console.log("componentWillReceiveProps,1");
      },
      shouldComponentUpdate:function(){
      console.log("shouldComponentUpdate,2");
      return true;
      },//得返回一个true,否则报错
      componentWillUpdate:function(){
      console.log("componentWillUpdate,3");
      },
      render:function(){
      console.log("render,4");
      return <p>Hello,{this.props.name ? this.props.name : "World"}</p>;
      },
      componentDidUpdate:function(){
      console.log("componentDidUpdate,5");
      },
      });
      var HelloUniverse=React.createClass({
      getInitialState:function(){
      return {name:""};
      },
      handleChange:function(event){
      //用来响应input的输入事件
      this.setState({name:event.target.value});
      },
      render:function(){
      return <div>
      <HelloWorld name={this.state.name
      //这里引用了HelloWorld的组件,所以HelloUniverse是他的子组件
      }></HelloWorld>
      <br />
      <input type="text" onChange={this.handleChange} />
      </div>
      },
      });
      React.render(<div style={style}><HelloUniverse></HelloUniverse></div>,document.body)
      // 写为React.render(<div style={style}><HelloWord></HelloWorld></div>,document.body)看看效果
      </script>
      </body>
      </html>

      没有输入内容的时候,只会触发render,

      每输入一次内容,就会触发一次。

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title></title>
      </head>
      <body>
      <script type="text/javascript" src="http://cdn.bootcss.com/jquery/2.0.3/jquery.min.js"></script>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/react.min.js"></script>
      <script type="text/javascript" src="http://cdn.bootcss.com/react/0.13.2/JSXTransformer.js"></script>
      <script type="text/jsx">
      $(document).ready(
      function(){
      var style={
      color:"red",
      border:"1px solid #f99",
      width:"200px",
      height:"50px"
      };
      var HelloWorld= React.createClass({
      componentWillReceiveProps:function(newProps){
      console.log("componentWillReceiveProps,1");
      console.log(newProps);
      },
      shouldComponentUpdate:function(){
      console.log("shouldComponentUpdate,2");
      return true;
      },//得返回一个true,否则报错
      componentWillUpdate:function(){
      console.log("componentWillUpdate,3");
      },
      render:function(){
      console.log("render,4");
      return <p>Hello,{this.props.name ? this.props.name : "World"}</p>;
      },
      componentDidUpdate:function(){
      console.log("componentDidUpdate,5");
      },
      });
      var HelloUniverse=React.createClass({
      getInitialState:function(){
      return {name:""};
      },
      handleChange:function(event){
      //用来响应input的输入事件
      this.setState({name:event.target.value});
      },
      render:function(){
      return <div>
      <HelloWorld name={this.state.name
      //这里引用了HelloWorld的组件,所以HelloUniverse是他的子组件
      }></HelloWorld>
      <br />
      <input type="text" onChange={this.handleChange} />
      </div>
      },
      });
      React.render(<div style={style}><HelloUniverse></HelloUniverse></div>,document.body)
      // 写为React.render(<div style={style}><HelloWord></HelloWorld></div>,document.body)看看效果
      })
      </script>
      </body>
      </html>

      查看一下输出,这里输出了一个object

react运行阶段的更多相关文章

  1. React组件生命周期-正确执行运行阶段的函数

    一. 二. <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset=" ...

  2. react - 解刨组件的多种写法

    一,原始的createClass写法 对于写react组件,很多人第一印象往往是createClass,这是因为createClass是react组件最原始的写法,基本每个学react的人都是接触这种 ...

  3. React实现动画效果

    流畅.有意义的动画对于移动应用用户体验来说是非常必要的.和React Native的其他部分一样,动画API也还在积极开发中,不过我们已经可以联合使用两个互补的系统:用于全局的布局动画LayoutAn ...

  4. 前端面试题总结(js、html、小程序、React、ES6、Vue、算法、全栈热门视频资源)

    写在前面 参考答案及资源在看云平台发布,如果大家想领取资源以及查看答案,可直接前去购买.一次购买永久可看,文档长期更新!有什么意见与建议欢迎您及时联系作者或留言回复! 文档描述 本文是关注微信小程序的 ...

  5. React 生命周期介绍

    [组件生命周期] 一.理论 组件本质上是状态机,输入确定,输出一定确定 生命周期的三个阶段,三者时间是不固定的,只是在逻辑上的分类: 二.初始化阶段: getDefaultProps:获取实例的默认属 ...

  6. React入门看这篇就够了

    摘要: 很多值得了解的细节. 原文:React入门看这篇就够了 作者:Random Fundebug经授权转载,版权归原作者所有. React 背景介绍 React 入门实例教程 React 起源于 ...

  7. React及Nextjs相关知识点小结

    React及Nextjs知识点小结 函数式组件和类组件区别是什么 1.函数式组件是用于创建无状态的组件,组件不会被实例化,无法访问this中的对象,无法访问生命周期方法,是无副作用的,相比于类组件函数 ...

  8. react 核心技术点

    1.react生命周期 react生命周期分为初始化阶段.运行阶段.销毁阶段. (1) 初始化阶段: componentWillMount:实例挂载之前 Render:渲染组件 componentDi ...

  9. 【React -- 4/100】 生命周期

    生命周期 概述 意义:组件的生命周期有助于理解组件的运行方式,完成更复杂的组件功能.分析组件错误原因等 组件的生命周期: 组件从被创建到挂载到页面中运行,再到组件不在时卸载的过程 生命周期的每个阶段总 ...

随机推荐

  1. python数据分析Numpy(二)

    Numpy (Numerical Python) 高性能科学计算和数据分析的基础包: ndarray,多维数组(矩阵),具有矢量运算能力,快速.节省空间: 矩阵运算,无需循环,可以完成类似Matlab ...

  2. P3089 [USACO13NOV]POGO的牛Pogo-Cow

    P3089 [USACO13NOV]POGO的牛Pogo-Cow FJ给奶牛贝西的脚安装上了弹簧,使它可以在农场里快速地跳跃,但是它还没有学会如何降低速度. FJ觉得让贝西在一条直线的一维线路上进行练 ...

  3. VMware vSphere克隆虚拟机

    参考资料:http://blog.csdn.net/shen_jz2012/article/details/48416771 1. 首先将你所要克隆的虚拟机关掉 2. 选择你的ESXI服务器     ...

  4. HDU 1730 类NIM模型

    两者间的间距就是可取石子数,因为对于行内黑白相连的局面该子游戏已经结束了因为此时不管先手再怎么移都是必败,SG=0的终止态 /** @Date : 2017-10-14 21:46:21 * @Fil ...

  5. CIKM Competition数据挖掘竞赛夺冠算法陈运文

    CIKM Competition数据挖掘竞赛夺冠算法陈运文 背景 CIKM Cup(或者称为CIKM Competition)是ACM CIKM举办的国际数据挖掘竞赛的名称.CIKM全称是Intern ...

  6. 原生JS不到30行,实现类似javascript MVC的功能-minTemplate

    严格来讲不能说是MVC,应为模版里不能写逻辑语句. 灵感来源于我的上篇文字:<封装JSON数据转自定义HTML方法parseHTML>: 这里再封装一个简单方法,在保持原来的方便改变不大的 ...

  7. 20155215 2016-2017-2 《Java程序设计》第7周学习总结

    20155215 2016-2017-2 <Java程序设计>第7周学习总结 教材学习内容总结 第十二章 lambda语法:Lambda去重复,回忆DRY原则,Lambda表达式可读性更好 ...

  8. Python super() 函数

    super() 函数是用于调用父类(超类)的一个方法. super 是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果重定义某个方法,该方法会覆盖父类的同名方法,但有时 ...

  9. 使用Cobbler批量部署Linux和Windows:CentOS/Ubuntu批量安装(二)

    通过前面服务端的部署,已经配置好了 Cobbler Server 端,接下来开始进行 CentOS/Ubuntu 的批量安装,在进行 CentOS/Ubuntu 批量安装时,也需要通过Cobbler来 ...

  10. C++ socket 网络编程 简单聊天室

    操作系统里的进程通讯方式有6种:(有名/匿名)管道.信号.消息队列.信号量.内存(最快).套接字(最常用),这里我们来介绍用socket来实现进程通讯. 1.简单实现一个单向发送与接收 这是套接字的工 ...