引入
受控组件和非受控组件的概念是从哪里来的呢?在HTML中,表单元素比如说input,textarea,select他们通常都是根据用户的输入来确定他们自己的状态,在React中可变状态通常保存在state中,只能通过this.setState()来进行修改
受控组件
假如说我们现在有一个表单,表单中有一个input标签,Input的value值必须设置在constructor构造函数中的state中,然后通过onChange来触发事件改变state中保存的value值,也就是说React负责渲染表单的组件仍然控制用户后续输入时所发生的变化
非受控组件
与受控组件相反,表单数据由dom元素自身管理的组件是非受控组件,意味着可以不设置它的state属性而是通过ref来操作真实的DOM
需要注意的是,非受控组件通常需要指定表单元素的初始值,不控制后续的更新,这种情况指定的是defaultVal属性而不是value属性