我是新来的人,当我单击“提交”按钮时,什么都没有发生?

如何解决我是新来的人,当我单击“提交”按钮时,什么都没有发生?

这是代码 实际上,这是一个非常新的反应,我正在做一个将要执行的项目,但是在执行此操作时,我却坚持在列表项中渲染输入字段的输出。如果还有其他解决方案,例如没有列表组,那将非常有帮助!

我在做实际的错误时,请有人看一下 预先感谢!

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>
);}}

导出认的MainPage;

解决方法

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>
);}}
,

尝试一下:

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>
,

您的代码中存在一些问题:

  1. 您要提交按钮。为此,您需要添加type="submit"
<button className="btn btn-primary btn-sm ml-3" type="submit">
    Submit
</button>

  1. 您需要为input维护两个状态,为todo's维护第二个状态。这样,您始终可以在用户提交表单时追加现有的待办事项:
state = { data: [],input: "" };
  1. 最后一次保存的是onSubmit,但还没有保存e.target.value,相反,您需要保存在onHandleChage

这里是完整代码:

import React,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",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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?