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 ...
随机推荐
- 从Encoder-Decoder模型入手,探索语境偏移解决之道
摘要:在本文中,我们展示了CLAS,一个全神经网络组成,端到端的上下文ASR模型,通过映射所有的上下文短语,来融合上下文信息.在实验评估中,我们发现提出的CLAS模型超过了标准的shallow fus ...
- 鲲鹏基础软件开发赛道openLooKeng赛题火热报名中,数十万大奖等您来收割
随着云计算.物联网.移动计算.智慧城市.人工智能等领域的发展,各类应用对大数据处理的需求也发生着变化.以实时分析.离线分析.交互式分析等为代表的计算引擎逐渐为各大企业行业发展所看重.作为鲲鹏产业生态的 ...
- 源码详解数据结构Linked List
摘要:java.util.LinkedList 是 Java 集合框架中的成员之一,底层是基于双向链表实现,集合容量可动态变化的. 本文分享自华为云社区<LinkedList 源码分析>, ...
- PPT 毕业答辩:学术风格的PPT
PPT 毕业答辩:学术风格的PPT 合适字体 便于阅读, 封面.标题 楷体.华康俪金黑.粗宋体.思源宋体.中山行书 正文 宋体.仿宋.微软雅黑.思源黑体 主题色 学术红.严谨紫.科学蓝 跟着LOGO ...
- C# 内存缓存工具类 MemoryCacheUtil
C# 内存缓存工具类 MemoryCacheUtil using System; using System.Collections.Concurrent; using System.Collectio ...
- Java Kafka 消费积压监控
Java Kafka 消费积压监控 后端代码: Monitor.java代码: package com.suncreate.kafkaConsumerMonitor.service; import c ...
- #1016:Prime Ring Problem(经典DFS)
原题链接 题意:很容易理解,就是让你输出满足相邻的相加是素数的序列(注意不要重复) 思路就是深搜思想把每种情况遍历一次 代码实现: #include<iostream> #include& ...
- AIsing Programming Contest 2020 游记 (ABC水题,D思维)
补题链接:Here A - Number of Multiples 水题 B - An Odd Problem 水题 C - XYZ Triplets 水题,注意数组不要开小了 D - Anythin ...
- Spring七种事务传播行为与五种事务隔离级别
一.事务的传播行为:通过Propagation定义: <!-- 配置事务通知 --><tx:advice id="txAdvice" transaction-ma ...
- Live Server插件打开浏览器时:该网页无法正常运作,127.0.0.1未发送任何数据的问题解决
一.问题复现 今天使用Vs Code写HTML代码时,使用Live Server打开预览时,发现浏览器显示"该网页无法正常运作,127.0.0.1未发送任何数据"的问题. 二.解决 ...