广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React受控组件与非受控组件深入讲解
  • 504
分享到

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

React受控组件React非受控组件 2022-12-26 12:12:31 504人浏览 薄情痞子
摘要

目录一、非受控组件二、受控组件三、高阶函数(函数柯里化)实现1、定义2、实现四、不用函数柯里化的实现一、非受控组件 表单中输入类DOM的值现用现取 <script type="

一、非受控组件

表单中输入类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 函数返回一个值然后放在一个函数里面

到此这篇关于React受控组件与非受控组件深入讲解的文章就介绍到这了,更多相关React受控组件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: React受控组件与非受控组件深入讲解

本文链接: https://www.lsjlt.com/news/175800.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • React受控组件与非受控组件深入讲解
    目录一、非受控组件二、受控组件三、高阶函数(函数柯里化)实现1、定义2、实现四、不用函数柯里化的实现一、非受控组件 表单中输入类DOM的值现用现取 <script type="...
    99+
    2022-12-26
    React受控组件 React非受控组件
  • React受控组件与非受控组件实例分析讲解
    目录一、受控组件二、非受控组件三、总结一、受控组件 在HTML中,表单元素的标签、、等的值改变通常是根据用户输入进行更新。 在React中,可变状态通常保存在组件的状态属性中,并且只...
    99+
    2023-01-18
    React受控组件与非受控组件 React受控组件 React非受控组件
  • React受控组件与非受控组件详细介绍
    目录1. 受控组件1.1 介绍1.2 受控组件简写1.3 在表单中使用受控组件1.4 综合案例2. 非受控组件介绍非受控组件的应用1. 受控组件 1.1 介绍 概述: 将 state...
    99+
    2022-11-13
  • React中怎么实现受控组件与非受控组件
    本篇文章给大家分享的是有关React中怎么实现受控组件与非受控组件,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。受控组件与非受控组件是Reac...
    99+
    2022-10-19
  • 浅析React中的受控组件和非受控组件
    目录非受控组件 受控组件 注意 结论 非受控组件 表单数据由DOM本身处理。即不受setState()的控制,与传统的HTML表单输入相似,input输入值即显示最新值(使用 re...
    99+
    2022-11-12
  • react非受控组件指的是什么
    这篇文章主要介绍“react非受控组件指的是什么”,在日常操作中,相信很多人在react非受控组件指的是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react非受控组件...
    99+
    2022-10-19
  • react受控组件和不受控组件的区别有哪些
    今天小编给大家分享的是react受控组件和不受控组件的区别有哪些,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。 reac...
    99+
    2022-10-19
  • react受控组件指的是什么
    这篇文章主要介绍“react受控组件指的是什么”,在日常操作中,相信很多人在react受控组件指的是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react受控组件指的是...
    99+
    2022-10-19
  • 如何理解React受控组件Hooks方式
    这篇文章主要介绍“如何理解React受控组件Hooks方式”,在日常操作中,相信很多人在如何理解React受控组件Hooks方式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2022-10-19
  • react中受控组件指的是什么
    本文小编为大家详细介绍“react中受控组件指的是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“react中受控组件指的是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。...
    99+
    2022-10-19
  • React源码中怎么实现受控组件
    本篇内容主要讲解“React源码中怎么实现受控组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“React源码中怎么实现受控组件”吧!在React中一个简单的受...
    99+
    2022-10-19
  • React中受控组件与数据共享的示例分析
    这篇文章主要介绍React中受控组件与数据共享的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:在HTML当中,像<input>,<textarea...
    99+
    2022-10-19
  • React如何使用Hooks简化受控组件的状态绑定
    这篇文章主要介绍React如何使用Hooks简化受控组件的状态绑定,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!ECMAScript 6文章中大量用到了 ES6 语法,比如解构赋值和...
    99+
    2022-10-19
  • Vue中父子组件通信与事件触发的深入讲解
    目录一、组件子组件父组件二、父子组件通信父组件给子组件通信子组件向父组件通信三、父子组件事件触发父组件调用子组件中的事件方法子组件调用父组件中的事件方法四、总结一、组件 子组件 &l...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作