Я новичок в react, и когда я нажимаю на кнопку отправки, ничего не происходит?

#reactjs #onsubmit

#reactjs #onsubmit

Вопрос:

Вот код!! На самом деле я очень новичок в react, и я работаю над проектом, который находится в списке дел, но при выполнении этого я застрял на рендеринге вывода поля ввода в элементе списка. если есть другое решение, например, без группы списков, это было бы очень полезно!

Где я делаю фактическую ошибку, пожалуйста, кто-нибудь, посмотрите на это, заранее спасибо!

 import React, { Component, Fragment } from "react";
class MainPage extends Component {
  state = { data: "" };
  handleChange = (e) => {
    e.preventDefault();};
  handleSubmit = (e) => {
    e.preventDefault();

    this.setState({ data: e.target.value });
  };



render() {
    const mystyle = {
      padding: "16px 16px 16px 60px",
      textAlign: "start",
      fontSize: "24px",
      fontFamily: 'Helvetica Neue", Helvetica, Arial, sans-serif',
      width: "500px",
    };

return (
  <Fragment>
    <h1 className="display-1 text-center" style={{ color: "#f7c6c6" }}>
      todos
    </h1>
    <form className="todo-form" onSubmit={this.handleSubmit}>
      <input
        type="text"
        onChange={this.handleChange.bind(this)}
        className="new-todo shadow-lg p-3 mb-5 bg-white rounded"
        style={mystyle}
        placeholder="What needs to be done?"
      />

      <button className="btn btn-primary btn-sm ml-3">Submit</button>

      <ul className="list-group">
        <li
          className="list-group-item disabled p-3 mb-5 w-50 p-3 mx-auto "
          style={{ width: "200px", fontSize: "24px" }}
        >
          {this.state.data}
        </li>
      </ul>
    </form>
  </Fragment>
);}}
  

экспортировать главную страницу по умолчанию;

Комментарии:

1. попробуйте добавить type =»submit» к вашей кнопке

Ответ №1:

В вашем коде есть некоторые проблемы:

  1. Вы хотите отправить по кнопке. Для этого вам нужно добавить type="submit"
 <button className="btn btn-primary btn-sm ml-3" type="submit">
    Submit
</button>

  
  1. Вам нужно поддерживать два состояния, первое для input и второе для todo's . Таким образом, вы всегда можете добавить в существующий todo, когда пользователь отправляет форму:
 state = { data: [], input: "" };
  
  1. Наконец, вы сохраняете значение, onSubmit но оно не имеет e.target.value вместо этого вам нужно сохранить в onHandleChage

Вот полный код:

 import React, { Component, Fragment } from "react";

class MainPage extends Component {
  state = { data: [], input: "" };
  handleChange = (e) => {
    e.preventDefault();
    this.setState({ input: e.target.value });
  };
  handleSubmit = (e) => {
    e.preventDefault();
    this.setState({ data: [...this.state.data, this.state.input], input: "" });
  };

  render() {
    const mystyle = {
      padding: "16px 16px 16px 60px",
      textAlign: "start",
      fontSize: "24px",
      fontFamily: 'Helvetica Neue", Helvetica, Arial, sans-serif',
      width: "500px"
    };

    return (
      <Fragment>
        <h1 className="display-1 text-center" style={{ color: "#f7c6c6" }}>
          todos
        </h1>
        <form className="todo-form" onSubmit={this.handleSubmit}>
          <input
            type="text"
            onChange={this.handleChange.bind(this)}
            value={this.state.input}
            className="new-todo shadow-lg p-3 mb-5 bg-white rounded"
            style={mystyle}
            placeholder="What needs to be done?"
          />

          <button className="btn btn-primary btn-sm ml-3" type="submit">
            Submit
          </button>

          <ul className="list-group">
            {this.state.data.map((data, i) => {
              return (
                <li
                  className="list-group-item disabled p-3 mb-5 w-50 p-3 mx-auto "
                  style={{ width: "200px", fontSize: "24px" }}
                  key={"todo-"   i}
                >
                  {data}
                </li>
              );
            })}
          </ul>
        </form>
      </Fragment>
    );
  }
}

export default function App() {
  return (
    <div className="App">
      <MainPage />
    </div>
  );
}

  

Вот демонстрация:https://codesandbox.io/s/xenodochial-banzai-qwxfu?file=/src/App.js:0-1762

Комментарии:

1. Я пробовал, и это работает отлично! Большое вам спасибо!

Ответ №2:

 import React, { Component, Fragment } from "react";
class MainPage extends Component {
  state = { data: "" };

  handleSubmit = (e) => {
    e.preventDefault();

    alert(data)
  };



render() {
    const mystyle = {
      padding: "16px 16px 16px 60px",
      textAlign: "start",
      fontSize: "24px",
      fontFamily: 'Helvetica Neue", Helvetica, Arial, sans-serif',
      width: "500px",
    };

return (
  <Fragment>
    <h1 className="display-1 text-center" style={{ color: "#f7c6c6" }}>
      todos
    </h1>
    <form className="todo-form" onSubmit={this.handleSubmit}>
      <input
        type="text"
        onChange={(e) => this.setState({data: e.target.value})}
        className="new-todo shadow-lg p-3 mb-5 bg-white rounded"
        style={mystyle}
        placeholder="What needs to be done?"
      />

      <button className="btn btn-primary btn-sm ml-3">Submit</button>

      <ul className="list-group">
        <li
          className="list-group-item disabled p-3 mb-5 w-50 p-3 mx-auto "
          style={{ width: "200px", fontSize: "24px" }}
        >
          {this.state.data}
        </li>
      </ul>
    </form>
  </Fragment>
);}}
  

Ответ №3:

Попробуйте, как:

 state = { data: "", FinalDataValue:"" };
 handleChange = (e) => {
e.preventDefault();
this.setState({ data: e.target.value });};


handleSubmit = (e) => {
e.preventDefault();
this.setState({ FinalDataValue:this.state.data });};
  

и в рендеринге в списке напишите это как :

 <li
      className="list-group-item disabled p-3 mb-5 w-50 p-3 mx-auto "
      style={{ width: "200px", fontSize: "24px" }}
    >
      {this.state.FinalDataValue}
    </li>