gpt4 book ai didi

reactjs - react 过滤列表

转载 作者:行者123 更新时间:2023-12-04 06:13:56 28 4
gpt4 key购买 nike

我无法理解下面代码笔中回调函数的逻辑。

就目前而言,当用户在输入字段中键入值时,列表会被过滤。如果过滤器被删除,我不知道如何恢复列表。

https://codepen.io/benszucs/pen/BPqMwL?editors=0010

  class Application extends React.Component {
state = {
options: ['Apple', 'Banana', 'Pear', 'Mango', 'Melon', 'Kiwi']
}
handleFilter = (newFilter) => {
if (newFilter !== "") {
this.setState(() => ({
options: this.state.options.filter(option => option.toLowerCase().includes(newFilter.toLowerCase()))
}));
}
};
render() {
return (
<div>
<Filter handleFilter={this.handleFilter} />
{this.state.options.map((option) => <p>{option}</p>)}
</div>
);
};
}

const Filter = (props) => (
<div>
<input name="filter" onChange={(e) => {
props.handleFilter(e.target.value);
}}/>
</div>
);

ReactDOM.render(<Application />, document.getElementById('app'));

最佳答案

由于您正在覆盖状态的原始值,因此您将无法反转它。我建议创建一个名为 filter 的新状态,并在 onChangeHandler() 中更新其值。在 render() 方法中,您应该在显示结果之前过滤结果。

例子:

// the state
this.state = {
users: ['abc','pdsa', 'eccs', 'koi'],
filter: '',
}

// the change handler
onChangeHandler(e) {
this.setState({
filter: e.target.value,
});
}

// displaying the results
const list = this.state.users.filter(u => u.includes(this.state.filter)).map(u => (
<li>{u}</li>
));

关于reactjs - react 过滤列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51747034/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com