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

引入

受控组件和非受控组件的概念是从哪里来的呢?在HTML中,表单元素比如说input,textarea,select他们通常都是根据用户的输入来确定他们自己的状态,在React中可变状态通常保存在state中,只能通过this.setState()来进行修改

受控组件

假如说我们现在有一个表单,表单中有一个input标签,Input的value值必须设置在constructor构造函数中的state中,然后通过onChange来触发事件改变state中保存的value值,也就是说React负责渲染表单的组件仍然控制用户后续输入时所发生的变化

非受控组件

与受控组件相反,表单数据由dom元素自身管理的组件是非受控组件,意味着可以不设置它的state属性而是通过ref来操作真实的DOM

需要注意的是,非受控组件通常需要指定表单元素的初始值,不控制后续的更新,这种情况指定的是defaultVal属性而不是value属性

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值