React获取DOM

React获取DOM的方法简述

createRef

当 ref 属性在组件时,获取组件实例;当ref属性在dom时,获取dom实例

findDOMNode

获取findDOMNode(this)参数组件(this)的DOM(所有DOM)

如果只是Fragment包裹,则只能获取其第一个子组件的DOM

例如:

获取的第一个子组件的DOM:<div>1</div>

<Fragment>
    <div>1</div>
    <div>2</div>
</Fragment>

获取的第一个子组件的DOM:<div><div>1</div><div>2</div></div>

<Fragment>
    <div>
        <div>1</div>
        <div>2</div>
    </div>
</Fragment>

forwardRef

用法:

const Child=React.forwardRef((props,ref)=>(
    <div>
        <span ref={ref}>child</span>
    </div>
))

通过上面包裹后,

class Parent extends Component{
    //...
    
    this.myRef=React.createRef();

    <Child ref={this.myRef} />
}

虽然ref在组件上,但还是能获取到Child的span.

另一种用法:获取的是input

const Child= React.forwardRef((props,ref)=>{
    class GrandChild extends React.Component{
        render(){
            return (
                <input ref={ref}/>
            )
        }
    }
    return (
        <div >
            child
            {props.children}
            <GrandChild />
        </div>
    )
})

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,422评论 19 139
  • It's a common pattern in React to wrap a component in an ...
    jplyue阅读 8,508评论 0 2
  • 深入JSX date:20170412笔记原文其实JSX是React.createElement(componen...
    gaoer1938阅读 12,465评论 2 35
  • 看着去年今天一起拍的照片 突然间我觉得之前的想法一直都是错的 我拿青春度明月 整日以无所谓的态度对待我的工作 然后...
    AI大叔阅读 1,911评论 0 0
  • 这几天各大媒体头条,被28岁男星乔任梁刷屏了。 他还很年轻,就这样离开了我们,表示惋惜和心痛。 究竟是什么夺走了他...
    现实主义鼻祖阅读 2,688评论 3 4