react诡异的input无法输入问题,createPortal来解决

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

这写Modal的时候遇到一个诡异的rea【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】ct问题,即input无法输入。不能说资【作者:唐霜】转载请注明出处:www.tangshuang.net深,但是对于自认为熟谙套路的react开本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net发者,检查了好几遍,调试了好一会儿,还是未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。解决不了。

【转载请注明来源】【访问 www.tangshuang.n【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。et 获取更多精彩内容】

就在我快要放弃的时候,我突然想到,是不是【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。所在组件树的上层组件在处理childre本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。n的时候对input做了处理?按理不该啊【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.net

【访问 www.tangshuang.n【版权所有,侵权必究】原创内容,盗版必究。et 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。

于是我对嵌套的上一层组件内部实现进行了检【作者:唐霜】原创内容,盗版必究。查,最后发现,果然是在Modal的实现中【未经授权禁止转载】本文作者:唐霜,转载请注明出处。,使用了ReactDOM.render来未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。更新渲染,从而实现延时的动画效果。果然是未经授权,禁止复制转载。未经授权,禁止复制转载。一大堆坑。

原创内容,盗版必究。【原创内容,转载请注明出处】【原创内容,转载请注明出处】

在实现Modal时,为了实现过渡动画,要【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.net采用一个特殊的办法,当DOM挂载好之后,【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】不能立即显示,而是要通过一个时间来过渡。【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。由于element.style的操作会合【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net并,一次性更新,所以当DOM卸载时,直接【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。就将Modal干掉了。因此,Modal组本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net件内部通过state维护了两个状态dis【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.netplay和visible。display【本文受版权保护】原创内容,盗版必究。用于控制DOM的挂载卸载,visible本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】用于控制显示隐藏。特别是在关闭Modal【原创不易,请尊重版权】原创内容,盗版必究。过程中,要先visible=false,【未经授权禁止转载】【本文首发于唐霜的博客】等过渡时间结束之后才能display=f著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】alse。

【版权所有,侵权必究】【版权所有,侵权必究】【转载请注明来源】

遇到这种情况,通过ReactDOM.re【原创不易,请尊重版权】【转载请注明来源】nder来更新DOM的操作就会导致inp未经授权,禁止复制转载。【本文首发于唐霜的博客】ut无法输入。因为render函数在做d【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】iff的时候,render是全量diff【本文受版权保护】【转载请注明来源】,在input没有key的情况下,Rea【作者:唐霜】【未经授权禁止转载】ctDOM无法确认是否其value要使用【版权所有,侵权必究】原创内容,盗版必究。对应值。甚至在其所在树的上层,就已经把它本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net干掉了。

本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。

通过createPortal可以解决这个【未经授权禁止转载】【版权所有,侵权必究】问题。

未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】ngnet】【版权所有,侵权必究】

ReactDOM.createPorta【未经授权禁止转载】【未经授权禁止转载】l用以创建一个React虚拟树,该虚拟树转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。被挂载在原虚拟树中,但是,在渲染到DOM【未经授权禁止转载】【访问 www.tangshuang.net 获取更多精彩内容】中时,却被挂载在createPortal【原创内容,转载请注明出处】【本文首发于唐霜的博客】的第二个参数上。

【原创内容,转载请注明出处】【本文首发于唐霜的博客】【原创不易,请尊重版权】

这就出现了一种不常见的现象:virtua未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。l dom和真实的DOM并非以相同的结构【原创内容,转载请注明出处】原创内容,盗版必究。存在。让我们来用代码演示一下。

著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】
class MyComponent extends Component {
  constructor(props) {
    super(props)
    this.el = document.createElement('div')
  }
  componentDidMount() {
    document.body.appendChild(this.el)
  }
  componentWillUnmount() {
    document.body.removeChild(this.el)
  }
  render() {
    return (
      <div className="root">
        {ReactDOM.createPortal(<div className="child">child</div>, this.el)}
        <div>xxx</div>
      </div>
    )
  }
}

上面这段代码,虽然在虚拟树中,.chil【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.netd是.root的第一个子节点,但是在真正【未经授权禁止转载】【转载请注明来源】的DOM中,.child被挂载在body未经授权,禁止复制转载。未经授权,禁止复制转载。下的一个空div中,这个空的div就是我【原创内容,转载请注明出处】【转载请注明来源】们在constructor中创建的那一个【原创内容,转载请注明出处】原创内容,盗版必究。

【版权所有】唐霜 www.tangshu【本文受版权保护】未经授权,禁止复制转载。ang.net【本文首发于唐霜的博客】

而通过createPortal创建的虚拟【版权所有】唐霜 www.tangshuang.net【本文受版权保护】树本身是属于react的元素树的一个节点【转载请注明来源】【未经授权禁止转载】,因此,在实际更新的时候,完全遵循rea原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netct的虚拟树逻辑,也就避免了文章开头提到转载请注明出处:www.tangshuang.net【版权所有,侵权必究】的问题。

【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。ngnet】转载请注明出处:www.tangshua本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】ng.net【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。【作者:唐霜】ang.net转载请注明出处:www.tangshua【原创不易,请尊重版权】转载请注明出处:www.tangshuang.netng.net