码迷,mamicode.com
首页 > 其他好文 > 详细

[React] useImperativeHandle + forwardRef

时间:2020-07-21 21:29:26      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:return   turn   click   sel   current   http   exp   app   The   

We have a message app:

技术图片

 

function App() {
    const messageDisplayRef = React.useRef()
    ....
    const scrollToTop = () => messageDisplayRef.current.scrollToTop()
    const scrollToBottom = () => messageDisplayRef.current.scrollToBottom()

    return (
        <div className="messaging-app">
            <button onClick={scrollToTop}>scroll to top</button>
            <Messages ref={messageDisplayRef}... />
            <button onClick={scrollToBottom}>scroll to bottom</button>
        </div>
    )
}

 

The idea is we want to control scrolling to top or bottom by two buttons from App. We pass the ‘ref‘ from App to Messages component.

 

function Messages(props, ref) {
    React.useLayoutEffect(() => {
        scrollToBottom()
    })

    function scrollToTop() { containerRef.current.scrollTop = 0 }
    function scrollToBottom() {containerRef.current.scrollTop = containerRef.current.scrollHeight}

    React.useImperativeHandle(ref, () => ({
        scrollToTop,
        scrollToBottom
    }))

    return (
        <div ref={containerRef}...>
              ...
        </div>
    )
}
Messages = React.forwardRef(Messages)

Since we use ‘forwardRef‘ for Messages component, so that it can receive a ‘ref‘ params.

 

We use ‘useImperativeHandle‘ to expose the ‘scrollToTop‘ & ‘scrollToBottom‘ APIs to parent component though ‘ref‘.

[React] useImperativeHandle + forwardRef

标签:return   turn   click   sel   current   http   exp   app   The   

原文地址:https://www.cnblogs.com/Answer1215/p/13355327.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!