react里面的value和defaultValue

广告位招租
扫码页面底部二维码联系

在react表单里面存在两种组件形式,一【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。种叫controlled compone【版权所有,侵权必究】未经授权,禁止复制转载。nt, 一种叫uncontrolled 转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。component。controlled原创内容,盗版必究。【未经授权禁止转载】的意思是说,你只能通过code去改变组件【关注微信公众号:wwwtangshuangnet】【转载请注明来源】的状态,比如checkbox,如果是co本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】ntrolled,那么你只能通过code【原创不易,请尊重版权】【转载请注明来源】去改变它的选中状态,而不能靠用户点击来修【未经授权禁止转载】【版权所有,侵权必究】改。而uncontrolled的组件反过本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】来,只能通过用户操作来改变状态,而不能通【未经授权禁止转载】转载请注明出处:www.tangshuang.net过code来改变。很可惜,一个react【本文受版权保护】转载请注明出处:www.tangshuang.net组件,不能在这两个形态之间转换,所以这对【原创不易,请尊重版权】【未经授权禁止转载】你写的code会有影响。

【转载请注明来源】本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.n本文版权归作者所有,未经授权不得转载。【本文受版权保护】et 获取更多精彩内容】

怎么区分呢?很简单,看你的代码是使用de【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】faultValue/defaultCh著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。ecked还是直接使用value/che【版权所有,侵权必究】【未经授权禁止转载】cked。如果是使用value/chec【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】ked,那么是controlled,反之【作者:唐霜】【未经授权禁止转载】则是unconrolled。

【本文受版权保护】转载请注明出处:www.tangshua【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。ng.net原创内容,盗版必究。【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。【未经授权禁止转载】ang.net

另外还有两个属性,disabled和re【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。adOnly,这两个属性其实要配合这两种【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】形态来使用。controlled com【访问 www.tangshuang.net 获取更多精彩内容】本文作者:唐霜,转载请注明出处。ponent只和readOnly配合,u【本文受版权保护】【转载请注明来源】ncontrolled componen本文作者:唐霜,转载请注明出处。原创内容,盗版必究。t只和disabled。如果一个inpu【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。t设置了value属性,但是没有给onC【本文受版权保护】【未经授权禁止转载】hange或readOnly,控制台会有本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】错误提示。这是因为,一个controll【作者:唐霜】本文版权归作者所有,未经授权不得转载。ed组件,它的创建一定要用于控制,而非为【访问 www.tangshuang.net 获取更多精彩内容】【未经授权禁止转载】了初始化一个值。这种情况下如果你想在外部转载请注明出处:www.tangshuang.net原创内容,盗版必究。去控制它,而不是它的onchange事件【作者:唐霜】【关注微信公众号:wwwtangshuangnet】中,那么应该添加readOnly,这样就【作者:唐霜】【关注微信公众号:wwwtangshuangnet】不会报错了。当然,这里的配合只是我的个人本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshuangnet】感悟,并非官方强制。

著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】【作者:唐霜】【转载请注明来源】