react 非授控组件和授控组件的区别

文章介绍了React中非授控组件和授控组件的区别。非授控组件通过ref从DOM获取数据,而授控组件的数据管理通过state进行,数据更新使用setState()。此外,还展示了授控组件的高阶函数与函数柯里化写法,以及不使用柯里化的实现方式。
摘要由CSDN通过智能技术生成

非授控组件
使用ref来从 DOM 节点中获取表单数据
表单数据将交由 DOM 节点来处理
非授控组件:先用先取

    //非受控组件:先用先取
    class Login extends React.Component {
     getSubmit=()=>{
     //阻止默认事件
     event.preventDefault()
     alert(`用户名:${this.ipt.value},密码:${this.iptT.value}`)
     }
      render() {
         return (
           <form action="https://developer.mozilla.org/" onSubmit={this.getSubmit}>
            姓名:<input ref={(a)=>{this.ipt=a}} type="text" name="username"/>
            密码:<input ref={(b)=>{this.iptT=b}} type="password" name="password"/>
            <button>登录</button>
           </form>
         )
      }
    }
   ReactDOM.render(<Login/>,document.getElementById("react"))

授控组件
表单组件的状态/数据只由state 维护 修改只能通过setState()来更新,
表单数据是由 React 组件来管理

   //受控组件就是数据维护在状态state中,当需要用的时候直接从状态中取出
    class Login extends React.Component {
   //初始化状态
   state={username:'', password:''}
   //自定义赋值事件
   getUserName=(event)=>{
      const {username} =this.state 
      this.setState({username:event.target.value})
    }
    getPassWord=(event)=>{
        const {password} =this.state
        this.setState({password:event.target.value})
    }
     getSubmit=()=>{
     //原生阻止默认事件
     event.preventDefault()
     const {password,username} =this.state
     alert(`姓名${username},密码${password}`)
     }
      render() {
         return (
           <form onSubmit={this.getSubmit}>
            姓名:<input onChange={this.getUserName} type="text" name="username"/>
                <h2>{this.state.username}</h2>
            密码:<input  onChange={this.getPassWord}  type="password" name="password"/>
                <h2>{this.state.password}</h2>
                <button>登录</button>
           </form>
         )
      }
    }
   ReactDOM.render(<Login/>,document.getElementById("react"))

授控组件用高阶函数与函数柯里化写法

//高阶函数,如果一个函数符合下面2个规范中的任何一个,那该函数就是高阶函数
   //   1.若A函数,接收的参数是一个函数,那么A就可以称高阶函数
   //   2.若A函数,调用的返回值依然是一个函数,那么A就可以称为高阶函数
   //    常见的高级函数有:Promise,setTimeout,map()等等
   //函数的柯里化:通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式
    class Login extends React.Component {
   //初始化状态
   state={username:'', password:''}
   //自定义赋值事件 ,这块属于高阶函数,
   getData=(data)=>{
    // console.log(data) //username,password
    // const {username,password} =data
      return (event)=>{
        //console.log("@") //onChange每改变一次,返回值的函数会被调用一次
          return this.setState({
            [data]:event.target.value
          })
      }
   }
     getSubmit=()=>{
     //原生阻止默认事件
     event.preventDefault()
     const {username,password} =this.state
     alert(`姓名${username},密码${password}`)
     }
      render() {
         return (
           <form onSubmit={this.getSubmit}>
                {/*这块this.getData("username")加了(),onChange把getData函数的返回值作为回调,不加(),会把getData函数本身作为回调*/}
            姓名:<input onChange={this.getData("username")} type="text" name="username"/>
                 <h2>{this.state.username}</h2>
            密码:<input  onChange={this.getData("password")}  type="password" name="password"/>
                <h2>{this.state.password}</h2>
                <button>登录</button>
           </form>
         )
      }
    }
   ReactDOM.render(<Login/>,document.getElementById("react"))

授控组件不用函数柯里化的写法

 class Login extends React.Component {
   //初始化状态
   state={username:'', password:''}
   getData=(datatest,e)=>{
    this.setState({[datatest]:e}) 
   }
   getSubmit=()=>{
     //原生阻止默认事件
     event.preventDefault()
     const {username,password} =this.state
     alert(`姓名${username},密码${password}`)
     }
      render() {
         return (
           <form onSubmit={this.getSubmit}>
                {/*这块this.getData("username")加了(),onChange把getData函数的返回值作为回调,不加(),会把getData函数本身作为回调*/}
            姓名:<input onChange={(event)=>{return this.getData("username",event.target.value)}} type="text" name="username"/>
                 <h2>{this.state.username}</h2>
            密码:<input onChange={event=>this.getData("password",event.target.value)} type="password" name="password"/>
                <h2>{this.state.password}</h2>
                <button>登录</button>
           </form>
         )
      }

    }
   ReactDOM.render(<Login/>,document.getElementById("react"))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鸥总

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值