State 结构设计
State 结构设计
接下来我们一起讨论下
const initialState = [
{ id: 1, text: "laundry" },
{ id: 2, text: "shopping" }, // ...
];
class List extends React.Component {
state = {
todos: initialState,
};
render() {
return (
<div>
<ul>
{this.state.todos.map((todo) => (
<li key={todo.id}>{todo.text}</li>
))}
</ul>
</div>
);
}
}
当你以为你大功告成的时候,产品经理让你添加一个搜索框,可以根据用户输入的内容动态地过滤列表显示内容。估计很多开发者会根据直觉写出如下代码:
class List extends React.Component {
state = {
todos: initialState,
filteredTodos: null,
};
search(searchText) {
const filteredTodos = this.state.todos.filter(
(todo) => todo.text.indexOf(searchText) > 0
);
this.setState({ filteredTodos: filteredTodos });
}
render() {
// get todos from state
const { filteredTodos, todos } = this.state; // if there are filtered todos use them
const list = filteredTodos === null ? todos : filteredTodos;
return (
<div>
<SearchBox onChange={this.search} />
<ul>
{list.map((todo) => (
<li key={todo.id}>{todo.text}</li>
))}
</ul>
</div>
);
}
}
从功能上来说,这段代码没有问题,但是其将todos
与filteredTodos
这两个属性的数据方可。在
class List extends React.Component {
state = {
todos: initialState,
searchText: null,
};
search(searchText) {
this.setState({ searchText: searchText });
}
filter(todos) {
if (!this.state.searchText) {
return todos;
}
return todos.filter((todo) => todo.text.indexOf(this.state.searchText) > 0);
}
render() {
const { todos } = this.state;
return (
<div>
<SearchBox onChange={this.search} />
<ul>
{this.filter(todos).map((todo) => (
<li key={todo.id}>{todo.text}</li>
))}
</ul>
</div>
);
}
}