React中受控组件与非受控组件的使用
受控组件
受控组件的步骤:
1.在state中添加一个状态,作为表单元素的value值(控制表单元素值的来源)
2.给表单元素绑定change事件,将表单元素的值设置为state的值(这样就可以控制表单元素值的变化)
受控组件的简单使用 index.js
import React from 'react'; //这个是react这个包,我们是需要的
import ReactDOM from 'react-dom'; //这个是react的虚拟dom
class ShowCont extends React.Component {
state = {
txet: '',
city: 'sh',
isChecked:''
}
// input的事件
changeTextHandler = (e) => {
this.setState({
txet:e.target.value
})
console.log(this.state.txet)
}
// 下拉框的事件
cityHandler = (e) => {
this.setState({
city:e.target.value
})
}
// 复选框的事件
changeCheck = (e) => {
this.setState({
isChecked:e.target.checked
})
}
// 获取的是所有的值
getAllHandler = () => {
console.log('获取的是所有的值:',this.state)
}
render() {
return (
<div>
{/* 普通的input */}
<input type="text" value={this.state.txet} onChange={this.changeTextHandler} />
{/* 下拉 */}
<select value={this.state.city} onChange={this.cityHandler} >
<option value="sh">上海</option>
<option value="bj">北京</option>
</select>
{/* 复选框 */}
<input type="checkbox" checked={this.state.isChecked} onChange={ this.changeCheck} />
<button onClick={this.getAllHandler}>获取值</button>
</div>
)
}
}
ReactDOM.render(<ShowCont/>, document.getElementById('root'))
受控组件的原理
文本框和文本域,下拉框操作的是value属性,通过change事件去更新。
复选框是通过checked属性和change事件去更新。
我们的发现
上面有不同的表单元素,如果表单元素有很多。
那我们是不是都要写不同的事件。去设置值呢?
这样操作会很麻烦的。
所以我们需要优化一下上面的代码。
我们发现:1.给表单元素添加name属性,名称与state相同。
value={this.state.txet} name='txet'
2.根据表单元素的类型获取对应的值
const formValue = target.type === 'checkbox'
? target.checked : target.value
3.在change事件中通过{name}来需要改对应的state中的值
this.setState({
[name]:formValue
})
优化上面的代码 index.js
import React from 'react'; //这个是react这个包,我们是需要的
import ReactDOM from 'react-dom'; //这个是react的虚拟dom
class ShowCont extends React.Component {
state = {
txet: '',
city: 'sh',
isChecked:''
}
// input
changeTextHandler = (e) => {
// 获取当前的dom对象
let target = e.target
// 根据类型获取值(key值)
let name = target.name
// 获取表单中的值
const formValue = target.type === 'checkbox' ? target.checked : target.value
// 设置值
this.setState({
[name]:formValue
})
}
// 获取的是所有的值
getAllHandler = () => {
console.log('获取的是所有的值:',this.state)
}
render() {
return (
<div>
{/* 普通的input */}
<input type="text" value={this.state.txet} name='txet' onChange={this.changeTextHandler} />
{/* 下拉 */}
<select value={this.state.city} name='city' onChange={this.changeTextHandler} >
<option value="sh">上海</option>
<option value="bj">北京</option>
</select>
{/* 复选框 */}
<input type="checkbox" checked={this.state.isChecked} name='isChecked' onChange={ this.changeTextHandler} />
<button onClick={this.getAllHandler}>获取值</button>
</div>
)
}
}
ReactDOM.render(<ShowCont/>, document.getElementById('root'))
非受控组件的使用方式
// 1.调用React.createRef()方法创建一个ref对象
this.textRef = React.createRef()
// 2.将创建好的ref对象添加到文本框中
<input type="text" ref={this.textRef} />
// 3. 通过ref对象获取文本框中的值
console.log('文本框中的值是:',this.textRef.current.value);
index.js使用非受控组件
import React from 'react'; //这个是react这个包,我们是需要的
import ReactDOM from 'react-dom'; //这个是react的虚拟dom
class ShowCont extends React.Component {
constructor() {
super()
// 1.调用React.createRef()方法创建一个ref对象
this.textRef = React.createRef()
}
getText = () => {
// 3. 通过ref对象获取文本框中的值
console.log('文本框中的值是:',this.textRef.current.value);
}
render() {
return (
<div>
{/* 2.将创建好的ref对象添加到文本框中 */}
<input type="text" ref={this.textRef} />
<button onClick={this.getText}>获取文本框中的值</button>
</div>
)
}
}
ReactDOM.render(<ShowCont/>, document.getElementById('root'))
React中受控组件与非受控组件的使用的更多相关文章
- react中 受控组件和 非受控组件 浅析
一 受控组件 顾名思义,受控 也就是能够被控制,简而言之也就是 该组件ui的显示或者内部state逻辑的变化依赖外部的 props的传入. 二 非受控组件 顾名思义,非受控,也就是内部的视图变化,st ...
- React:受控组件与非受控组件混用实战 - 译文
原文链接:React: hybrid controlled components in action 受控组件 非受控组件 混用受控组件和非受控组件 原则一 原则二 原则三 原则四 实施方案 总结 F ...
- 浅谈react受控组件与非受控组件
引言 最近在使用蚂蚁金服出品的一条基于react的ant-design UI组件时遇到一个问题,编辑页面时input输入框会展示保存前的数据,但是是用defaultValue就是不起作用,输入框始终为 ...
- React受控组件和非受控组件
受控组件和非受控组件主要是用来解决表单组件状态谁来控制的问题.因为用户的输入会反应在界面上,相当于视图的状态发生了变化,而react是通过虚拟DOM比对修改视图的,这里就要决定谁来控制表单组件的状态. ...
- react 表单(受控组件和非受控组件)
我们知道表单元素与其他的普通DOM元素来说是不一样的,它们保存了自己的一些状态. 我们主要说的就是表单元素中的受控组件和非受控组件. 受控组件就是这个组件的状态是我们(react)控制的,这个组件的行 ...
- react第十一单元(受控组件和非受控组件-实现类似于vue双向绑定的功能)
第十一单元(受控组件和非受控组件-实现类似于vue双向绑定的功能) #课程目标 理解因为react的单向数据流 理解表单组件会因为react数据流变的不好维护 理解受控组件与非受控组件的实质区别 理解 ...
- react组件之非受控组件和高阶组件
非受控组件 受控组件和非受控组件的区别 ----- value import React, { Component } from 'react' export default class extend ...
- Vue父子组件及非父子组件如何通信
1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: 子组件通过props来接收数据: 方式1: 方式2 : 方式3: 这样呢,就实现了父组件向子组件传递数 ...
- react中受控组件与非受控组件--
非受控组件:随用随取 1 render() { 2 return ( 3 <div> 4 <h1>非受控组件</h1> 5 <form action=&quo ...
- 学习React系列(四)——受控组件与非受控组件
受控组件:通过组件的状态与属性的改变来控制组件 不可控组件:直接通过底层的dom来控制组件(具体来说就是通过绑定再底层dom上的方法来实现的,比如说ref,onChange) 受控组件 functio ...
随机推荐
- “互联网+”大赛之AI创新应用赛题攻略:大胆脑洞,共绘智慧生活蓝图
摘要:本次"互联网+"大赛AI创新应用赛题的设置是希望学生可以从日常实际应用需求出发,结合自己的奇思妙想,提升智能终端用户的使用体验,为构建万物互联的智能世界贡献一份力量. 本文分 ...
- 宝藏昇腾AI应用推荐!CANN带你体验黑白图像自动上色的快乐~
摘要:属于"你"那边的麦田 天空 河水 骏马 树木--会是什么颜色呢? 黑白与色彩 似乎把时代分割了两半~ 我在这头看见了错乱繁华,琳琅满目,看见快速消长的色彩缤纷. 翻开一张黑白 ...
- 火山引擎DataTester分享:A/B实验中常见的8个错误
火山引擎DataTester是科学可信的A/B测试与智能优化平台,源自字节跳动长期沉淀,能够深度耦合推荐.广告.搜索.UI.产品功能等多种行业场景需求,为业务增长.转化.产品迭代,运营提效等各环节提供 ...
- Axure 表格中根据条件设置不同的字体样式--中继器
中继器+表格,根据条件设置不同的字体样式 思路:根据情形,设置不同的颜色,因为Axure 不能直接对元件的样式进行交互设置,所以借助[动态面板]进行设置 绘制表格详见:https://www.cnbl ...
- c#-微软
1)使用c#编写第一个程序简介: c#编程语言允许你构建多种类型的应用程序,例如: 用于捕获,分析和处理数据的业务应用程序 可从Web浏览器访问的动态Web应用程序 2D和3D游戏 金融和科研应用程序 ...
- GIL 锁或将在 CPython 中成为可选项
哈喽大家好,我是咸鱼 几天前有媒体报道称,经过多次辩论,Python 指导委员会打算批准通过 PEP 703 提案,让 GIL(全局解释器)锁在 CPython 中成为一个可选项 PEP 703 提案 ...
- Kotlin 协程真的比 Java 线程更高效吗?
本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/-OcCDI4L5GR8vVXSYhXJ7w作者:吴越 网上几乎全部介绍Kotlin的文章都会说 ...
- vue学习笔记 二、环境搭建+项目创建
系列导航 vue学习笔记 一.环境搭建 vue学习笔记 二.环境搭建+项目创建 vue学习笔记 三.文件和目录结构 vue学习笔记 四.定义组件(组件基本结构) vue学习笔记 五.创建子组件实例 v ...
- el-menu菜单过长,显示不全问题
- 运行vue项目时报错“ValidationError: Progress Plugin Invalid Options”
https://blog.csdn.net/M_Nobody/article/details/123135041?spm=1001.2101.3001.6650.1&utm_medium=di ...