加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

React全栈-社交网络程序 提交表单数据

发布时间:2020-12-15 20:35:23 所属栏目:百科 来源:网络整理
导读:1. 给每个input 表格添加change 事件 当input? 变化时触发 div className="form-group" input type="text" className="form-control form-control-lg" placeholder="用户名" name="name" value={this.state.name} onChange={this.onChange} / /div onchange

1. 给每个input 表格添加change 事件

当input? 变化时触发

 <div  className="form-group">
                    <input
                      type="text"
                      className="form-control  form-control-lg"
                      placeholder="用户名"
                      name="name"
                      value={this.state.name}
                      onChange={this.onChange}
                    />
                </div>

  

onchange事件:

//获取输入的值,每个值对应相对应的名字 
  onChange(e) {
    this.setState({ [e.target.name]: e.target.value });
  }

 e.target.value :表示input? 输入的内容? ?e.target.name:表示输入框对应的名字

2.添加表格提交事件

  <form onSubmit={this.onSubmit}>
         .......
 </form>

  onSubmit 事件:

onSubmit(e) {
       //阻止默认的行为哦
       e.preventDefault();
       const newUser = {
         name: this.state.name,email: this.state.email,password: this.state.password,password2: this.state.password2
       };
       console.log(newUser)
      //  { name: "zxw",email: "[email?protected]",password: "123",password2: "123"}
      //     email: "[email?protected]"
      //     name: "zxw"
      //     password: "123"
      //     password2: "123"
      //     __proto__: Object
      //  }
      }

  记得绑定this 的指向:

constructor() {
    super();
    this.state = {
      name: ‘‘,email: ‘‘,password: ‘‘,password2: ‘‘,errors: {}
    };

    this.onChange = this.onChange.bind(this);
    this.onSubmit = this.onSubmit.bind(this);
  }

  完整代码

import React,{ Component } from ‘react‘
class Register extends Component {
  constructor() {
    super();
    this.state = {
      name: ‘‘,errors: {}
    };

    this.onChange = this.onChange.bind(this);
    this.onSubmit = this.onSubmit.bind(this);
  }
  //获取输入的值,每个值对应相对应的名字 
  onChange(e) {
    this.setState({ [e.target.name]: e.target.value });
  }

  onSubmit(e) {
       //阻止默认的行为哦
       e.preventDefault();
       const newUser = {
         name: this.state.name,email: "[email?protected]",password2: "123"}
      //     email: "[email?protected]"
      //     name: "zxw"
      //     password: "123"
      //     password2: "123"
      //     __proto__: Object
      //  }
      }
  render() {
    return (
      <div className="register">
        <div className="container">
          <div className="row">
            <div className="col-md-8 m-auto">
              <h1 className="display-4 text-center">注册</h1>
              <p className="lead text-center">创建新的账户</p>
              <form onSubmit={this.onSubmit}>
                <div  className="form-group">
                    <input
                      type="text"
                      className="form-control  form-control-lg"
                      placeholder="用户名"
                      name="name"
                      value={this.state.name}
                      onChange={this.onChange}
                    />
                </div>
                <div  className="form-group">
                    <input
                      type="email"
                      className="form-control  form-control-lg"
                      placeholder="邮箱地址"
                      name="email"
                      info="我们使用了gravatar全球公认头像,如果需要有头像显示,请使用在gravatar注册的邮箱"
                      value={this.state.email}
                      onChange={this.onChange}
                    />
               </div>
               <div  className="form-group">
                    <input
                      className="form-control  form-control-lg"
                      type="password"
                      placeholder="密码"
                      name="password"
                      value={this.state.password}
                      onChange={this.onChange}
                    />
              </div>
              <div  className="form-group">
                <input
                  type="password"
                  className="form-control  form-control-lg"
                  placeholder="确认密码"
                  name="password2"
                  value={this.state.password2}
                  onChange={this.onChange}
                />
               </div>
                <input type="submit" className="btn btn-info btn-block mt-4" />
              </form>
            </div>
          </div>
        </div>
      </div >
    )
  }
}
export default Register;

  

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读