我有一个使用es6类符号定义的react组件。在render函数中,我尝试使用传播符号将一些状态变量传递到子组件中: render() { return ( // <div>{console.log(this.state.data)}</div> <Table {...{ data, columns, infinite, debug: true }} /> ); }这不起作用:data is not defined。使用this.state.data和state.data也不起作用(导致Unexpected keyword 'this'和Unexpected token)。但是,取消注释<div>{console.log(this.state.data)}</div>表明状态在范围内。最后,这可行:<Table data={this.state.data} columns={this.state.columns}/>在这种情况下,我是否会以某种方式滥用传播符号?我已经看到它可以在React函数组件中工作。
1 回答

慕容森
TA贡献1853条经验 获得超18个赞
我认为您使用的是错误的变量。 data确实是不确定的。您的实际数据在于this.state.data
render() {
return (
// <div>{console.log(this.state.data)}</div>
<Table
{...{
data: this.state.data,
columns: this.state.columns,
infinite,
debug: true
}}
/>
);
}
你可以试试这个吗?
添加回答
举报
0/150
提交
取消