挂载与卸载
挂载过程
四个方法:
- constructor:构造器
- componentWillMount:渲染前
- render:渲染
- componentDidMount:渲染后
import {Component} from "react";
class App extends Component {
constructor(props) {
super(props);
console.log("constructor")
}
render() {
console.log("render")
return (
<div>
</div>
)
}
componentWillMount() {
console.log('componentWillMount')
}
componentDidMount() {
console.log('componentDidMount')
}
}
export default App;
效果: data:image/s3,"s3://crabby-images/f1a53/f1a53b2e4f7437a828fbf74e100499a71c052ac6" alt="在这里插入图片描述"
案例:计时器
渲染后开启定时器。
import {Component} from "react";
class App extends Component {
state = {
count: 0
}
render() {
return (
<div>
<h1>{this.state.count}</h1>
</div>
)
}
componentDidMount() {
setInterval(() => {
this.setState({
count: this.state.count + 1
})
}, 1000)
}
}
export default App;
效果:
data:image/s3,"s3://crabby-images/d0a94/d0a948eebaeb90b8f763955f1cd4a2e2a29f0144" alt="在这里插入图片描述"
卸载之前
很简单,componentWillUnmount。
import {Component} from "react";
import * as ReactDOM from "react-dom";
class App extends Component {
render() {
return (
<div>
<button onClick={() => {
ReactDOM.unmountComponentAtNode(document.getElementById('app'))
}}>卸载
</button>
</div>
)
}
componentWillUnmount() {
console.log('componentWillUnmount')
}
}
export default App;
效果: data:image/s3,"s3://crabby-images/45cb0/45cb00acdfc9982eb311686c9d9936cbdb1a524c" alt="在这里插入图片描述"
更新
触发更新的情况
setState方法,可以触发更新。这个很简单。
父组件更新时,props发生变化,可以触发更新。 forceUpdate方法,强制更新。
import {Component} from "react";
class A extends Component {
render() {
console.log("render")
return (
<div>{this.props.count || 0}</div>
)
}
}
class App extends Component {
state = {
count: 0
}
render() {
return (
<div>
<A count={this.state.count}/>
<button onClick={() => {
this.setState({
count: this.state.count + 1
})
}}>+
</button>
<button onClick={() => {
this.forceUpdate()
}}>强制更新
</button>
</div>
)
}
}
export default App;
props变化导致更新:
data:image/s3,"s3://crabby-images/3c483/3c4832ebc77647473161a1df626f1a1c652b3277" alt="在这里插入图片描述" 强制更新:
data:image/s3,"s3://crabby-images/9e087/9e0872e074b636493a7ccdca563492938c1b0308" alt="在这里插入图片描述"
更新前后
很简单:
- componentWillUpdate
- componentDidUpdate
import {Component} from "react";
class App extends Component {
state = {
count: 0
}
render() {
return (
<div>
<h1>{this.state.count}</h1>
<button onClick={() => {
this.setState({
count: this.state.count + 1
})
}}>+
</button>
</div>
)
}
componentWillUpdate(nextProps, nextState, nextContext) {
console.log('componentWillUpdate')
console.log(nextProps)
console.log(nextState)
console.log(nextContext)
}
componentDidUpdate(prevProps, prevState, snapshot) {
console.log('componentDidUpdate')
console.log(prevProps)
console.log(prevState)
console.log(snapshot)
}
}
export default App;
效果:
data:image/s3,"s3://crabby-images/3939b/3939b2bb84dffc3baa1eaa40a12e44982cf5d074" alt="在这里插入图片描述"
拦截更新
强制更新之外的两种方式,可以由shouldComponentUpdate方法进行拦截判断。 返回假则不更新,返回真则更新。
举例:只有变成偶数的时候才更新。
import {Component} from "react";
class App extends Component {
state = {
count: 0
}
render() {
return (
<div>
<h1>{this.state.count}</h1>
<button onClick={() => {
this.setState({
count: this.state.count + 1
})
}}>+
</button>
</div>
)
}
shouldComponentUpdate(nextProps, nextState, nextContext) {
return nextState.count % 2 === 0;
}
}
export default App;
效果:
data:image/s3,"s3://crabby-images/cfce1/cfce19665e72bb4d1f77c6ff2fa7b57df40fb2ea" alt="在这里插入图片描述"
props变化前
父组件中props发生变化导致的更新,会调用一次componentWillReceiveProps方法。
import {Component} from "react";
class A extends Component {
render() {
return (
<div>{this.props.count || 0}</div>
)
}
componentWillReceiveProps(nextProps, nextContext) {
console.log('componentWillReceiveProps')
console.log(nextProps)
console.log(nextContext)
}
}
class App extends Component {
state = {
count: 0
}
render() {
return (
<div>
<A count={this.state.count}/>
<button onClick={() => {
this.setState({
count: this.state.count + 1
})
}}>+
</button>
<button onClick={() => {
this.forceUpdate()
}}>强制更新
</button>
</div>
)
}
}
export default App;
效果:
data:image/s3,"s3://crabby-images/14516/145164666ffb55b2854e88110491e27872c6f2a3" alt="在这里插入图片描述"
生命周期
data:image/s3,"s3://crabby-images/3fda8/3fda8c6272c420c839d0316eb0607a11f061346d" alt="在这里插入图片描述"
番外:两个新的生命周期方法
官方文档地址:
getDerivedStateFromProps() getSnapshotBeforeUpdate()
|