再看React生命周期

单个React组件的生命周期应该知道了吧,不知道看这https://facebook.github.io/react/docs/react-component.html
经常用到,也经常被面试官问到

当父子组件嵌套的时候构造函数和render之间的先后关系是啥,根据dom tree结构的特点,肯定是递归调用的,对于virtual dom的diff算法有兴趣的可以看这https://supnate.github.io/react-dom-diff/index.html,做了几个可视化还是挺有意思的。下面来看下父子嵌套的生命周期吧。

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Hello React!</title>
    <script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
    <script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
    <script src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"></script>
  </head>
  <body>
    <div id="example"></div>
    <script type="text/babel">
      class A extends React.Component{
        constructor(props){super(props);console.log('A created');}
        render(){console.log('A render');return <span>A</span>}
        componentDidMount(){console.log('A rendered');}
      }

      class B extends React.Component{
        constructor(props){super(props);console.log('B created');}
        render(){console.log('B render');return <span>B<A/></span>}
        componentDidMount(){console.log('B rendered');}
      }

      class C extends React.Component{
        constructor(props){super(props);console.log('C created');}
        render(){console.log('C render');return <span>C<B/></span>}
        componentDidMount(){console.log('C rendered');}
      }
      ReactDOM.render(
        <C/>,
        document.getElementById('example')
      );
    </script>
  </body>
</html>

console 输出

C created
C render
B created
B render
A created
A render
A rendered
B rendered
C rendered

备注

代码可以直接复制到这里 http://www.runoob.com/try/try.php?filename=try_react_hw 测试

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值