react受控组件和非受控组件区别

news/2024/11/20 23:15:11/

一、受控组件

在HTML中,表单元素的标签、、等的值改变通常是根据用户输入进行更新。
在React中,可变状态通常保存在组件的状态属性中,并且只能使用 setState() 进行更新,而呈现表单的React组件也控制着在后续用户输入时该表单中发生的情况,以这种由React控制的输入表单元素而改变其值的方式,称为受控组件。
比如,给表单元素input绑定一个onChange事件,当input状态发生变化时就会触发onChange事件,从而更新组件的state。

import React, { Component } from 'react'
export default class MyInput extends Component{constructor(props) {super(props);this.state = {value: 0}}handleChange = (event)=>{this.setState({value: event.target.value})}render(){return(<div><inputtype="text"value={this.state.value}onChange={this.handleChange}/></div>)}
}

受控组件更新state的流程

  1. 可以通过初始state中设置表单的默认值
  2. 每当表单的值发生变化时,调用onChange事件处理器
  3. 事件处理器通过事件对象event拿到改变后的状态,并更新组件的state
  4. 一旦通过setState方法更新state,就会触发视图的重新渲染,完成表单组件的更新

React中数据是单项流动的,从示例中,可以看出表单的数据来源于组件的state,并通过props传入,这也称为单向数据绑定。然后又通过onChange事件处理器将新的数据写回到state,完成了双向数据绑定。

二、非受控组件

非受控组件指的是,表单数据由DOM本身处理。即不受setState()的控制,与传统的HTML表单输入相似,input输入值即显示最新值。
在非受控组件中,可以使用一个ref来从DOM获得表单值。

class NameForm extends React.Component {constructor(props) {super(props);this.handleSubmit = this.handleSubmit.bind(this);}handleSubmit(event) {console.log('A name was submitted: ' + this.input.value);event.preventDefault();}render() {return (<form onSubmit={this.handleSubmit}><label>Name:<input type="text" ref={(input) => this.input = input} /></label><input type="submit" value="Submit" /></form>);}
}

非受控组件在底层实现时是在其内部维护了自己的状态state,这样表现出用户输入任何值都能反应到元素上。

三、总结

两者区别

  1. 受控组件
    受控组件依赖于状态
    受控组件的修改会实时映射到状态值上,此时可以对输入的内容进行校验
    受控组件只有继承React.Component才会有状态
    受控组件必须要在表单上使用onChange事件来绑定对应的事件
  2. 非受控组件
    非受控组件不受状态的控制
    非受控组件获取数据就是相当于操作DOM
    非受控组件可以很容易和第三方组件结合,更容易同时集成 React 和非 React 代码
    选择受控组件还是非受控组件
  3. 受控组件使用场景:一般用在需要动态设置其初始值的情况。例如:某些form表单信息编辑时,input表单元素需要初始显示服务器返回的某个值然后进行编辑。
  4. 非受控组件使用场景:一般用于无任何动态初始值信息的情况。例如:form表单创建信息时,input表单元素都没有初始值,需要用户输入的情况。

http://www.ppmy.cn/news/12495.html

相关文章

Python学习笔记-PyQt6消息窗

对话框是界面编程中重要的窗体&#xff0c;一般用于提示或者一些其他特定操作。一、使用QDialog显示通用消息框直接使用QDialog类&#xff0c;可以及通过对话框进行通用对话框显示&#xff0c;亦可以通过自定义设置自己需要的对话框。# _*_ coding:utf-8 _*_import sysfrom PyQ…

Linux 中断子系统(八):中断处理流程

1、上层中断处理 系统初始化时,已经建立起 硬件中断号 和 软件中断号的 映射表。 中断注册时,我们需要先从设备树中获取硬件中断号,然后调用 API 将硬件中断号转换为软件中断号,根据软件终端号 irq 找到对应的 irq_desc,并将中断处理函数添加到 irq_desc 中(也就是 irq…

【C语言进阶】使用“动态内存文件处理”实现进阶版通讯录

目录 前言 改进后的优势 一、test.c 二、contact.h 三、contact.c 1.加载通讯录函数load_contact 2、将数据保存到文件save_contact函数 3、初始化通讯录init_contact函数 4、扩容check_full函数 5、销毁通讯录destory_contact函数 6、其余函数 四、完整源码 总结 …

java伪随机数生成器

关于随机数的基本概念 1、对随机数性质分类&#xff1a; 随机性&#xff1a;符合该性质的叫弱伪随机数。这种随机数仅可以用于一般应用&#xff0c;无法用在密码学&#xff0c;例如java中的java.util.Random类不可预测性&#xff1a;符合该性质的叫强伪随机数。在密码学中&am…

Redis 实现用户积分和积分排行榜微服务优化

文章目录修改添加积分方法积分排行控制层redis实现积分排行业务逻辑层Redis排行榜测试使用 JMeter 压测对比在之前的博客中我通过 MySQL数据库实现了积分和积分排行榜功能&#xff0c;在数据量大和并发量高的情况下会有以下缺点&#xff1a;SQL编写复杂&#xff1b;数据量大&am…

Pytorch优化器全总结(四)常用优化器性能对比 含代码

目录 写在前面 一、优化器介绍 1.SGDMomentum 2.Adagrad 3.Adadelta 4.RMSprop 5.Adam 6.Adamax 7.AdaW 8.L-BFGS 二、优化器对比 优化器系列文章列表 Pytorch优化器全总结&#xff08;一&#xff09;SGD、ASGD、Rprop、Adagrad Pytorch优化器全总结&#xff08;二…

Python【3】:格式化输出

文章目录前言1. 通过 %\%% 实现1.1. 语法1.2. 常见格式化符号1.3. 格式化操作符辅助指令2. 通过 format() 函数实现2.1. 语法2.2. 用法2.2.1. 基本用法2.2.2. 数字格式化前言 在做题与实际应用中&#xff0c;经常会出现需要格式化&#xff08;输出&#xff09;字符串的情况&am…

走近软件生态系统

生态系统&#xff08;Ecosystem&#xff09;原本是一个生物学术语&#xff0c;意思是由一些生命体相互依存、相互制约而形成的大系统&#xff0c;就像我们学生时代在生物学课堂上学到的那样。隐喻无处不在&#xff0c;人们把这个术语移植到了 IT 领域中来&#xff0c;比如我们常…