我正在练习React,正在制作TodoList组件。但目前,我可以添加一个空的待办事项。我想要一条消息说这是不允许的。

我的问题是,即使该字段为空,我也可以创建一个新项目。

这是我的代码:

import React, { Component } from "react";

class TodoList extends Component {
    constructor() {
        super();
        this.state = {
            userInput: '',
            items: []
        };
    }

    onChange(event) {
        this.setState({
            userInput: event.target.value
        }, () => console.log(this.state.userInput));
    }

    addTodo(event) {
        event.preventDefault();
        this.checkField();
        this.setState({
            userInput: '',
            items: [...this.state.items, this.state.userInput] },
            () => console.log(this.state.items));
    }

    deleteTodo(item) {
        const array = this.state.items;
        const index = array.indexOf(item);
        array.splice(index, 1);
        this.setState({
            items: array
        })
    }

    checkField() {
        if(this.state.userInput.length === 0) {

            let emptyMessageDom = document.createElement("p");
            document.body.appendChild(emptyMessageDom);
            emptyMessageDom.innerHTML ="This is empty!!"

        }
    }

    renderTodos() {
        return this.state.items.map((item, index) => {
            return (
            <div key={index}>
                {item} {index} | <button onClick={this.deleteTodo.bind(this, item)}>X</button>
            </div>)
        })
    }

    render() {
        return(
            <div>
                <form>
                    <input
                        value={this.state.userInput}
                        type="text"
                        placeholder="New item"
                        onChange={this.onChange.bind(this)}
                        required
                    />
                    <button onClick={this.addTodo.bind(this)}>Add</button>
                </form>
                <div>
                    {this.renderTodos()}

                </div>
            </div>
        );
    }
}

export default TodoList;


我试图将函数checkField()的代码放入addTodo()函数的setState中,但是它不起作用。

提前致谢!

最佳答案

您应该使用状态来显示错误消息。这将有助于清理呈现和删除消息的方式。 Heres a full working example

更新addTodo以根据您的条件有条件地添加。

addTodo(event) {
  event.preventDefault();
  if (!this.checkField()) {
    return
  }
  this.setState({
    userInput: '',
    items: [...this.state.items, this.state.userInput]
  })
}


然后更新checkField以验证并返回一个布尔值

checkField() {
  if(this.state.userInput.length === 0) {
    this.setState({error: 'Field is required.'})
    return false;
  }
  return true;
}


然后您可以更新渲染部分以显示错误消息

<form>
  <input
    value={this.state.userInput}
    type="text"
    placeholder="New item"
    onChange={this.onChange.bind(this)}
    required
  />
  {!!this.state.error && <label>{this.state.error}</label>}
  <button onClick={this.addTodo.bind(this)}>Add</button>
</form>


最后,当输入发生更改事件时,最后不要忘记删除错误,因为现在验证已过期。

onChange(event) {
  this.setState(
    {
      userInput: event.target.value,
      error: ''
    }
  );
}

10-07 17:37