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