[英]React state variable updates automatically without calling setState
[英]react js state variable updates automatically without setstate method
我正在做一个React JS项目。 我有一个状态变量,并在componentDidMount()
方法期间用另一个普通变量( x
)初始化了该状态变量( x_state
)。 但是,只要我的常规变量( x
)得到更新,它就会自动更新状态变量( x_state
)。
export class Demo extends React.Component {
constructor(props) {
super(props);
this.state = {
x_state: null
}
this.x = {}
}
componentDidMount() {
this.setState({
x_state: this.x
})
}
}
局部变量this.x将在代码中的特定条件下更新。 每当本地变量this.x更新时,它都会自动更新状态变量x_state。 如何防止自动更新或自动setstate方法调用
这是因为x
是一个对象,并且您正在通过此代码设置引用
this.setState({
x_state: this.x
})
您应该使用Object.assign()
复制它
this.setState({
x_state: Ojbect.assign({},this.x)
})
或者如果this.x
最初是嵌套对象,则可以使用JSON.parse(JSON.stringify())
this.setState({
x_state: JSON.parse(JSON.stringify(this.x))
})
@Maheer Ali和@adiga是正确的。 由于状态变量x_state
和局部变量this.x
指向内存中的同一对象,因此它们都将一起更新。
您也可以使用Spread运算符将本地对象的属性复制到状态变量。
this.setState({
x_state: { ...this.x }
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.