React中的受控组件与非受控组件

受控组件与非受控组件

受控组件

组件(input, select)的状态与state的值绑定,组件的状态全程响应外部数据

jsx 复制代码
class TestComponent extends React.Component {
  constructor (props) {
    super(props);
    this.state = { username: 'lindaidai' };
  }
  render () {
    return <input name="username" value={this.state.username} />
  }
}

这时候当我们在输入框输入内容的时候,会发现输入的内容并无法显示出来,也就是input标签是一个可读的状态

这是因为valuethis.state.username所控制住。当用户输入新的内容时,this.state.username并不会自动更新,这样的话input内的内容也就不会变了

如果想要解除被控制,可以为input标签设置onChange事件,输入的时候触发事件函数,在函数内部实现state的更新,从而导致input框的内容页发现改变

因此,受控组件我们一般需要初始状态和一个状态更新事件函数。

非受控组件

一般情况是在初始化的时候接受外部数据,然后自己在内部存储其自身状态

即组件的状态不受React控制的组件

当需要时,可以使用ref 查询 DOM 并查找其当前值,如下:

jsx 复制代码
import React, { Component } from 'react';

export class UnControll extends Component {
  constructor (props) {
    super(props);
    this.inputRef = React.createRef();
  }
  handleSubmit = (e) => {
    console.log('我们可以获得input内的值为', this.inputRef.current.value);
    e.preventDefault();
  }
  render () {
    return (
      <form onSubmit={e => this.handleSubmit(e)}>
        <input defaultValue="lindaidai" ref={this.inputRef} />
        <input type="submit" value="提交" />
      </form>
    )
  }
}

我们一般只有在一次性取值时才推荐使用非受控组件,比如提交表单的所有数据,否则大多数情况下都推荐使用受控组件

相关推荐
鹏程十八少11 分钟前
12. Android 协程通关秘籍:31 道资深工程师面试题精讲
前端·后端·面试
Dlrb121123 分钟前
C语言-字符串指针与函数指针
java·c语言·前端
PBitW28 分钟前
组件封装注意事项
前端·vue.js
weiggle33 分钟前
Android 输入事件分发流程:从物理触控到 Activity 的完整旅程
前端
yingyima37 分钟前
开发者必备在线工具集合 2025:实战案例解析
前端
前端毕业班38 分钟前
面试官:实现一个带类型约束的 EventEmitter
前端·面试
卷帘依旧41 分钟前
SPA 中的 Hash 和 History 模式
前端
用户4445543654261 小时前
AndroidAutoSize使用时遇到的特麻烦bug
前端
茉莉玫瑰花茶1 小时前
LangGraph 入门教程:构建 AI 工作流 [ 案例三 ]
前端·人工智能·python
scan7241 小时前
pydantic格式输出
服务器·前端·javascript