React受控组件与非受控组件深入讲解

一、非受控组件

表单中输入类DOM的值现用现取

<script type="text/babel">
        //创建组件
        class Login extends React.Component{
                handleSubmit = (event)=>{
                        event.preventDefault() //阻止表单提交
                        const {username,password} = this
                        alert(`你输入的用户名是:${username.value},你输入的密码是:${password.value}`)
                }
                render(){
                        return(
                                <form onSubmit={this.handleSubmit}>
                                        用户名:<input ref={c => this.username = c} type="text" name="username"/>
                                        密码:<input ref={c => this.password = c} type="password" name="password"/>
                                        <button>登录</button>
                                </form>
                        )
                }
        }
        //渲染组件
        ReactDOM.render(<Login/>,document.getElementById('test'))
</script>

二、受控组件

表单中输入类DOM的值,随着输入,能把输入的值维护到状态state中,需要用的时候再从状态中取出来。建议写受控组件,可以减少ref的使用

<script type="text/babel">
        //创建组件
        class Login extends React.Component{
                //初始化状态
                state = {
                        username:'', //用户名
                        password:'' //密码
                }
                //保存用户名到状态中
                saveUsername = (event)=>{
                        this.setState({username:event.target.value})
                }
                //保存密码到状态中
                savePassword = (event)=>{
                        this.setState({password:event.target.value})
                }
                //表单提交的回调
                handleSubmit = (event)=>{
                        event.preventDefault() //阻止表单提交
                        const {username,password} = this.state
                        alert(`你输入的用户名是:${username},你输入的密码是:${password}`)
                }
                render(){
                        return(
                                <form onSubmit={this.handleSubmit}>
                                        用户名:<input onChange={this.saveUsername} type="text" name="username"/>
                                        密码:<input onChange={this.savePassword} type="password" name="password"/>
                                        <button>登录</button>
                                </form>
                        )
                }
        }
        //渲染组件
        ReactDOM.render(<Login/>,document.getElementById('test'))
</script>

三、高阶函数(函数柯里化)实现

1、定义

(1)高阶函数

如果一个函数符合下面2个规范中的任何一个,那该函数就是高阶函数。

1.若A函数,接收的参数是一个函数,那么A就可以称之为高阶函数。 2.若A函数,调用的返回值依然是一个函数,那么A就可以称之为高阶函数。 常见的高阶函数有:Promise、setTimeout、arr.map()等等

(2)函数的柯里化

通过函数调用继续返回函数的方式,实现多次接收参数最后统一处理的函数编码形式。

function sum(a){
        return(b)=>{
                return (c)=>{
                        return a+b+c
                }
        }
}

2、实现

<script type="text/babel">
        class Login extends React.Component{
                state = {
                        username:'', //用户名
                        password:'' //密码
                }
                //保存表单数据到状态中
                saveFormData = (dataType)=>{
                        return (event)=>{
                                this.setState({[dataType]:event.target.value})
                        }
                }
                //表单提交的回调
                handleSubmit = (event)=>{
                        event.preventDefault() //阻止表单提交
                        const {username,password} = this.state
                        alert(`你输入的用户名是:${username},你输入的密码是:${password}`)
                }
                render(){
                        return(
                                <form onSubmit={this.handleSubmit}>
                                        用户名:<input onChange={this.saveFormData('username')} type="text" name="username"/>
                                        密码:<input onChange={this.saveFormData('password')} type="password" name="password"/>
                                        <button>登录</button>
                                </form>
                        )
                }
        }
        ReactDOM.render(<Login/>,document.getElementById('test'))
</script>

onChange绑定的必须是一个函数,this.saveFormData()调用saveFormData 函数的返回值是一个函数

四、不用函数柯里化的实现

<script type="text/babel">
        class Login extends React.Component{
                state = {
                        username:'', //用户名
                        password:'' //密码
                }
                //保存表单数据到状态中
                saveFormData = (dataType,event)=>{
                        this.setState({[dataType]:event.target.value})
                }
                //表单提交的回调
                handleSubmit = (event)=>{
                        event.preventDefault() //阻止表单提交
                        const {username,password} = this.state
                        alert(`你输入的用户名是:${username},你输入的密码是:${password}`)
                }
                render(){
                        return(
                                <form onSubmit={this.handleSubmit}>
                                        用户名:<input onChange={event => this.saveFormData('username',event) } type="text" name="username"/>
                                        密码:<input onChange={event => this.saveFormData('password',event) } type="password" name="password"/>
                                        <button>登录</button>
                                </form>
                        )
                }
        }
        //渲染组件
        ReactDOM.render(<Login/>,document.getElementById('test'))
</script>

this.saveFormData()调用saveFormData 函数返回一个值然后放在一个函数里面

原文地址:https://blog.csdn.net/m0_46613429/article/details/128332218