ES6 包含但不区分大小写

IT技术 javascript reactjs ecmascript-6
2021-05-20 18:01:45

我知道我可以遍历数组并更改 value toLowerCase()

我很好奇是否有一个reactjsores6方法可以检查值是否在数组中。

关于 addTodo 功能。您可以看到我使用了包含,但此方法区分大小写。

这是我所拥有的

class Todo extends React.Component {
    render() {
        return (
            <div className="todo">
                <input type="checkbox" />
                <p>{this.props.children}</p>
            </div>
        );
    }
}

class App extends React.Component {
    constructor(props) {
        super(props);

        this.todos = [
            'Get Up from bed', 
            'Eat Breakfast'
        ];
    }

    eachTodo(task, i) {
        return (
            <Todo key={i} index={i}>{task}</Todo>
        )
    }

    addToDo() {
        let task_title = this.refs.newTodo.value;

        if(task_title !== '') {
            let arr = this.todos;

            var arr_tlc = this.todos.map((value) => {
                return value.toLowerCase();
            })

            if(arr_tlc.indexOf(task_title.toLowerCase()) === -1) {
                arr.push(task_title);

                this.setState({
                    todos: arr
                });
            }
        }
    }

    render() {
        return (
            <div className="main-app">
                <input ref="newTodo" placeholder="Task"/>
                <button onClick={this.addToDo.bind(this)}>Add Todo</button>

                <div className="todos">
                    {this.todos.map(this.eachTodo)}
                </div>
            </div>

        );
    }   
}

任何帮助,将不胜感激。谢谢!

2个回答

我建议Map您的待办事项列表使用 a而不是数组。AMap的优点是它在恒定时间内提供基于键的查找,并且不会存储具有相同键的重复条目。然后,您可以使用小写变体作为键,并将原始(混合大小写)字符串用作该键的值。

您可以定义todos为 aMap而不是数组,并使用小写字符串作为键:

constructor(props) {
    super(props);
    this.todos = new Map();
    this.addToDo('Get Up from bed'); 
    this.addToDo('Eat Breakfast');
}

然后,添加任务变得非常简单,因为Map覆盖重复项:

addToDo() {
    this.todos.set(task_title.toLowerCase(), task_title);
    this.setState({
        todos: this.todos
    });
 }

在渲染中,您需要使用Array.from(..., <map-function>),因为.map没有为Map对象定义

<div className="todos">
    {Array.from(this.todos, this.eachTodo)}
</div>

这意味着该eachToDo方法将接收一对字符串(一个数组),而不是一个字符串,我们希望显示该对的第二个,因此使用 index [1]

eachTodo(task, i) {
    return (
        <Todo key={i} index={i}>{task[1]}</Todo>
    )
}

不,唯一的内置方法区分大小写。您将需要该循环和toLowerCase不区分大小写的正则表达式(可能隐藏在有用的可重用函数中)。