The
import { Component } from "react";
interface Props {}
interface State {
color: string
}
export default class App extends Component{
constructor(props: Props) {
super(props)
this.state = {color: "green"};
this.changeColor = this.changeColor.bind(this)
}
componentDidUpdate() {
console.log("Component Did Update")
}
changeColor() {
this.setState((prevState) => {
if(prevState.color === "green"){
return {color: "blue"}
}
else{
return {color: "green"}
}
})
}
render(){
return <button
style={{color: this.state.color}}
onClick={this.changeColor}>
Change Color
</button>
}
}
Whenever I click the
componentDidUpdate() {
console.log("Component Did Update")
this.setState({color: "yellow"})
}
In this situation,
The equivalent React hook is the
import { useEffect, useState } from "react"
export const FunctionalComponent = () =>{
const [color, setColor] = useState("green")
useEffect(() => {
console.log("Component Did Update")
})
const changeColor = () => {
setColor((prevColor) => {
if(prevColor === "green"){
return "blue"
}
else{
return "green"
}
})
}
return(
<button style={{color: color}} onClick={changeColor}>Change Color</button>
)
}
If I run this component, I will see the console log output "useEffect" whenever I click the "Change Color" button. Further clicks on the "Change Color" would trigger the useEffect() hook because of the state updates.