锐英源软件
第一信赖

精通

英语

开源

擅长

开发

培训

胸怀四海 

第一信赖

当前位置:锐英源 / 开源技术 / React / 生命周期方法
服务方向
人工智能数据处理
人工智能培训
kaldi数据准备
小语种语音识别
语音识别标注
语音识别系统
语音识别转文字
kaldi开发技术服务
软件开发
运动控制卡上位机
机械加工软件
软件开发培训
Java 安卓移动开发
VC++
C#软件
汇编和破解
驱动开发
联系方式
固话:0371-63888850
手机:138-0381-0136
Q Q:396806883
微信:ryysoft

React生命周期方法


刚接触 React 的时候就发现了 API 里有一系列的 componentXXX 方法,通常这些方法会在「应用程序生命周期的特定时间点」被执行。但是在实际写代码的过程中,这样模糊的说法还是不能解决所有的疑惑。


mixin 中的方法先执行

var DummyMixin = {      
componentDidMount: function(){      
console.log('mixin');    
}  
};  
var DummyClass = React.createClass({      
mixins: [DummyMixin],    
componentDidMount: function(){      
console.log('component');    
},    
render: function(){      
return null;    
}  
});

将 DummyClass 渲染到 DOM 节点在 console 中输出的结果是:

mixin    component  

DEMO

因此可以确认如果在 mixin 中和组件中同时定义了某个生命周期方法,mixin 中的方法会先执行。


重复 mount 一个组件

var DummyClass = React.createClass({      
render: function(){      
return null;    
}  
});  
React.render(<DummyClass />, document.body);    
React.render(<DummyClass />, document.body);  

都有哪些生命周期方法被调用,它们的顺序又是怎样的呢?

/* 第一次 render */  getDefaultProps    
getInitialState    
componentWillMount    
render    
componentDidMount    
/* 第二次 render */  componentWillReceiveProps    
shouldComponentUpdate    
componentWillUpdate    
render    
componentDidUpdate  

从 mount 到 unmount

var DummyClass = React.createClass({      
render: function(){      
return null;    
}  
});  
React.render(<DummyClass />, document.body);    
React.unmountComponentAtNode(document.body);  

调用结果是:

/* mount */  getDefaultProps    
getInitialState    
componentWillMount    
render    
componentDidMount    
/* unmount */  componentWillUnmount  

这里再提一个小问题,先 mount 一个组件再 unmount 再 mount,生命周期方法的调用情况是怎样的?


第三方代码控制生命周期

如果是你使用了 react-router 等第三方库来控制你组件的生命周期,你可能不能直观的掌握组件什么时候会被 mount,什么时候会被 unmount。

这个时候你可以使用react-lifecycle mixin,将这个 mixin 添加到你需要观察的组件中,当任何生命周期方法被调用时,你都能在 console 中看到对应的日志。

当然,这个 mixin 不会输出 render 方法的调用。

友情链接
版权所有 Copyright(c)2004-2021 锐英源软件
公司注册号:410105000449586 豫ICP备08007559号 最佳分辨率 1024*768
地址:郑州大学北校区院(文化路97号院)内