Gie*_*ius 2 javascript state reactjs
我想从渲染函数访问refs,并将其设置为状态.
这是我的代码:
export default class App extends Component {
constructor(props) {
super();
this.arr = this.generateTimelineArray();
this.state = {el : 'empty'};
}
componentDidMount() {
this.setState({
el: this.refs.el
});
console.log(this.state.el)
}
render() {
return (
<div className="timeline__container--line" ref="el" ></div>
);
}
Run Code Online (Sandbox Code Playgroud)
我可以console.log(this.refs.el)和值记录.但我必须将它保存到构造函数以将其传递给另一个组件.
问题是国家没有改变.
我究竟做错了什么?
提前致谢
setState是异步的.文件.如果要查看更新的状态,请使用回调.
componentDidMount() {
this.setState({
el: this.refs.el
}, () => console.log(this.state.el));
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
818 次 |
| 最近记录: |