码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 如何理解受控和非受控件组件?


    受控组件: 受控组件是React中的一种组件,其特点是输入框的值(value)由React状态(state)控制。也就是说,React中的状态变化会直接影响输入框的值。受控组件通过form的输入元素(input, select等)的value属性绑定到状态上,然后通过onChange事件来更新状态。也就是说,用户在输入框中的输入会触发onChange事件,然后更新React状态,进而重新渲染组件。

    例如:

    1. class Controlled extends React.Component {
    2. constructor(props) {
    3. super(props);
    4. this.state = {
    5. inputValue: '',
    6. };
    7. }
    8. handleInputChange = (event) => {
    9. this.setState({
    10. inputValue: event.target.value,
    11. });
    12. };
    13. render() {
    14. return (
    15. <input
    16. type="text"
    17. value={this.state.inputValue}
    18. onChange={this.handleInputChange}
    19. />
    20. );
    21. }
    22. }
    1. 非受控组件: 非受控组件与受控组件相反,输入框的值不由React状态控制,而是由用户输入的内容直接赋值。非受控组件只接受并响应来自用户的事件,例如onChange事件。它们不会影响输入元素的值。非受控组件主要用于处理一些不希望React状态改变的场景,例如一些只读或者只写的输入框。

    例如:

    1. class Uncontrolled extends React.Component {
    2. constructor(props) {
    3. super(props);
    4. }
    5. handleInputChange = (event) => {
    6. console.log(event.target.value); // 输出用户输入的值
    7. };
    8. render() {
    9. return (
    10. <input
    11. type="text"
    12. value={this.props.value} // 由外部传入的值控制输入框的值
    13. onChange={this.handleInputChange}
    14. />
    15. );
    16. }
    17. }

    总结:受控和非受控是两种处理表单输入元素的方式,受控组件完全依赖于React的状态和事件系统,而非受控组件则更加自由,但也需要自行处理更多的事情。

  • 相关阅读:
    深圳大学计软《程序设计基础》实验三 选择结构
    打造自己的3D模型AI 自动纹理工具
    你所不知道的 vscode,汇集历史版本中你可能不知道的新特性
    FastestDet---模型训练
    Flutter笔记:GetX模块中不使用 Get.put 怎么办
    Redis HyperLogLog的使用
    maven学习:附件
    Git Flow 的正确使用姿势
    JavaScript 63 JavaScript 对象 63.1 JavaScript 对象定义
    Biotin-C6-amine_N-生物素基-1,6-己二胺_CAS:65953-56-2_100mg
  • 原文地址:https://blog.csdn.net/zybijiso666/article/details/132921789
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号