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