在react表单里面存在两种组件形式,一【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】种叫controlled compone【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。nt, 一种叫uncontrolled 著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.netcomponent。controlled本文版权归作者所有,未经授权不得转载。【转载请注明来源】的意思是说,你只能通过code去改变组件【本文首发于唐霜的博客】【本文受版权保护】的状态,比如checkbox,如果是co转载请注明出处:www.tangshuang.net【转载请注明来源】ntrolled,那么你只能通过code原创内容,盗版必究。【关注微信公众号:wwwtangshuangnet】去改变它的选中状态,而不能靠用户点击来修【本文首发于唐霜的博客】未经授权,禁止复制转载。改。而uncontrolled的组件反过著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。来,只能通过用户操作来改变状态,而不能通【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】过code来改变。很可惜,一个react著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。组件,不能在这两个形态之间转换,所以这对【原创内容,转载请注明出处】原创内容,盗版必究。你写的code会有影响。
著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net怎么区分呢?很简单,看你的代码是使用de【原创不易,请尊重版权】【本文受版权保护】faultValue/defaultCh【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。ecked还是直接使用value/che未经授权,禁止复制转载。【版权所有,侵权必究】cked。如果是使用value/chec本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】ked,那么是controlled,反之本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net则是unconrolled。
转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。另外还有两个属性,disabled和re【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】adOnly,这两个属性其实要配合这两种【原创不易,请尊重版权】原创内容,盗版必究。形态来使用。controlled com本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】ponent只和readOnly配合,u本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。ncontrolled componen【作者:唐霜】【本文受版权保护】t只和disabled。如果一个inpu本文版权归作者所有,未经授权不得转载。【本文受版权保护】t设置了value属性,但是没有给onC【未经授权禁止转载】【转载请注明来源】hange或readOnly,控制台会有转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net错误提示。这是因为,一个controll【未经授权禁止转载】【作者:唐霜】ed组件,它的创建一定要用于控制,而非为【原创不易,请尊重版权】【关注微信公众号:wwwtangshuangnet】了初始化一个值。这种情况下如果你想在外部本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net去控制它,而不是它的onchange事件本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】中,那么应该添加readOnly,这样就【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。不会报错了。当然,这里的配合只是我的个人转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】感悟,并非官方强制。
【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。
