zoukankan      html  css  js  c++  java
  • React 表单与事件 简单演示

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    import './index.css';
    import * as serviceWorker from './serviceWorker';
    
    class MyInput extends Component{
      constructor(props){
        super(props);
        this.state={
          text:'请输入内容'
        }
        this.textFn=this.textFn.bind(this);
      }
    
      textFn(e){
          this.setState({
            text:e.target.value
          })
      }
    
      render(){
        return(
          <div>
            <input type="text" onChange={this.textFn} placeholder={this.state.text}/>
            <p>{this.state.text}</p>
          </div>
        )
      }
    }
    
      ReactDOM.render(
        <div>
           <MyInput />
        </div>,
        document.getElementById('example')
      );
    
    serviceWorker.unregister();

    如何在子组件上使用表单
    在父组件通过创建事件句柄 (handleChange) ,并作为 prop (updateStateProp) 传递到子组件上

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    import './index.css';
    import * as serviceWorker from './serviceWorker';
    
    class Parent extends Component{
      constructor(props){
        super(props);
        this.state={
          text:'请输入内容'
        }
        this.textFn=this.textFn.bind(this);
      }
    
      textFn(e){
          this.setState({
            text:e.target.value
          })
      }
    
      render(){
        return(
          <Child textFn={this.textFn} text={this.state.text} />
        )
      }
    }
    
    class Child extends Component{
      render(){
        return(
          <div>
            <input type="text" onChange={this.props.textFn} placeholder={this.props.text}/>
            <p>{this.props.text}</p>
          </div>
        )
      }
    }
    
      ReactDOM.render(
        <div>
           <Parent />
        </div>,
        document.getElementById('example')
      );
    
    serviceWorker.unregister();

    在 React 中,不使用 selected 属性,而在根 select 标签上用 value 属性来表示选中项

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    import './index.css';
    import * as serviceWorker from './serviceWorker';
    
    class Select extends Component{
      constructor(props){
        super(props);
        this.state={
          text:''
        }
        this.selectFn=this.selectFn.bind(this);
        this.submitFn=this.submitFn.bind(this);
      }
    
      selectFn(e){
          this.setState({
            text:e.target.value
          })
      }
    
      submitFn(e){
        console.log('you choosed '+this.state.text);
        e.preventDefault();
    }
    
      render(){
        return(
          <form onSubmit={this.submitFn}>
            <select value={this.state.text} onChange={this.selectFn}>
              <option value="a">a</option>
              <option value="b">b</option>
              <option value="c">c</option>
            </select>
            <input type="submit" value="提交" />
          </form>
        )
      }
    }
    
      ReactDOM.render(
        <div>
           <Select />
        </div>,
        document.getElementById('example')
      );
    
    serviceWorker.unregister();

    处理多个 input 元素时,可以给每个元素添加一个 name 属性,来让处理函数根据 event.target.name 的值来选择做什么

    import React, { Component } from 'react';
    import ReactDOM from 'react-dom';
    import './index.css';
    import * as serviceWorker from './serviceWorker';
    
    class Select extends Component{
      constructor(props){
        super(props);
        this.state={
          text:true,
          num:4
        }
        this.changeFn=this.changeFn.bind(this);
      }
    
      changeFn(e){
        const value=e.target.type==='checkbox' ? e.target.checked : e.target.value;
        const name=e.target.name;
          this.setState({
            [name]:value
          })
      }
    
      render(){
        return(
          <form>
            <input type="checkbox" name="text" checked={this.state.text} onChange={this.changeFn} />
            <br/>
            <input type="number" name="num" value={this.state.num} onChange={this.changeFn} />
          </form>
        )
      }
    }
    
      ReactDOM.render(
        <div>
           <Select />
        </div>,
        document.getElementById('example')
      );
    
    serviceWorker.unregister();

  • 相关阅读:
    ASP.NET 取得 Uri 各项属性值
    js获取当前时间显示在页面上
    脚步提示及跳转
    整体刷新和局部刷新frameset窗口
    asp.net 字符串过滤
    .net 获取当前网页的的url
    优酷去广告最新的关于如何屏蔽优酷广告的方法
    bat命令集合
    修复IE
    网易见外工作台(AI),语音转文字,快速制作字幕,中英翻译,在线修改字幕
  • 原文地址:https://www.cnblogs.com/chenyingying0/p/12698470.html
Copyright © 2011-2022 走看看