我正在开发一个简单的“待办事项清单”React应用程序(对React.js不太熟悉)。我已经实现了向列表中添加项目,但删除项目则引起了一个问题。在我的父级React组件中,我有以下代码:
import ToDoEntries from './to_do_entries.jsx';
class ToDoList extends React.Component {
constructor(props) {
super(props);
this.state = { list: [] }
this.add = this.addItem.bind(this);
this.removeItem = this.removeItem.bind(this);
}
addItem(e) { //removed to avoid tl:dr }
render() {
return(
<form onSubmit={this.add}>
<input placeholder='Enter item' type='text' ref={(el) => {this._input = el;} }/>
<button>Add</button>
</form>
<ToDoEntries entries={this.state.list}
removeCallback={this.removeItem}
/>
);
}
}
我的to_do_entries.jsx
组件:
class ToDoEntries extends React.Component {
constructor(props) {
super(props);
}
renderItems() {
const { entries, removeCallback } = this.props;
function createTasks(item) {
return <li key={item.key}>{item.text}</li>
}
var listItems = entries.map(function(item) {
return(<li onClick={removeCallback} key={item.key}>{item.text}</li>)
})
return listItems;
}
render() {
var todoEntries = this.renderItems();
return(
<ul>
{todoEntries}
</ul>
);
}
}
export default ToDoEntries;
运行此代码会出现以下情况:
警告:setState(...):无法在现有状态转换期间更新
问题:
为什么当添加一个项目时,to_do_entries.jsx的渲染立即执行回调函数?
var listItems = entries.map(function(item) {
return(<li onClick={removeCallback(id)} key={item.key}>{item.text}</li>)
})
然而,将.bind(null, id)
添加到removeCallback函数中,如 <li onClick={removeCallback.bind(null, id)} />
,结果不起作用?
onClick={removeCallback(id)}
会立即触发/调用 removeCallback,而onClick={removeCallback.bind(null, id)}
却不会立即触发/调用 removeCallback? - Johnthis
上下文和函数回调,即functionName()
与function
,让我感到困惑已经有一段时间了。@John - soups