我是 React 新手,我喜欢在父组件本身中维护状态,并将相同的状态传递给子组件上的所有子组件我想从父组件状态更新子状态,我正在使用 getDerivedStateFromProps 来更新它。但我想我做错了,因为值在内部级别对象中更新,比如内部状态有一个名为状态的级别对象,我也尝试过传播它,但它没有用。
父组件
import React from 'react';
import './App.css';
import Navbar from './components/Navbar';
class App extends React.Component {
state = {
name: 'Kannan',
countryCode: '',
mobile: '',
isModalOpen: false,
};
render() {
return (
<div className="App">
<Navbar params={this.state}></Navbar>
</div>
);
}
}
export default App;
子组件
class NavbarComponent extends React.Component {
constructor(props) {
super(props);
console.log(props.params);
this.state = {};
}
static getDerivedStateFromProps(props, state) {
console.log(state);
return { state: props.params };
// return {state: { ...props.params }} ;
}
render() {
console.log(this.state);
return (
<div>
"Something"
</div>
);
}
}
我已经尝试使用 { state: ...props.params} 以及渲染 console.log 中的 {state: props.params} 我得到
{state: {…}}
state: {name: "Kannan", countryCode: "", mobile: "", isModalOpen: false}
__proto__: Object
我期待的是
state: {name: "Kannan",countryCode:"",mobile:"",isModalOpen:false}
注意: 没有 REDUX。我不想使用REDUX如果还有其他更好的方法来更新子组件状态?另外,我想知道为每个子组件维护状态是否是一种好习惯?任何帮助表示赞赏