From dcf0205537c7cd6298984e1a49dc0249a27400fe Mon Sep 17 00:00:00 2001 From: Shawnchen <1004740775@qq.com> Date: Sat, 30 Jan 2021 19:13:56 +0800 Subject: [PATCH] fix: typo --- lessons/hooks-in-depth.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lessons/hooks-in-depth.md b/lessons/hooks-in-depth.md index 1b5c9ade..447c6299 100644 --- a/lessons/hooks-in-depth.md +++ b/lessons/hooks-in-depth.md @@ -92,7 +92,7 @@ Here's one you will likely never directly use but you may use libraries that use In the example above, whenever you have an _invalid_ form, it will immediately focus the the first field that's invalid. If you look at the code, `ElaborateInput` is a child element so the parent component shouldn't have any access to the input contained inside the component. Those components are black boxes to their parents. All they can do is pass in props. So how do we accomplish it then? -The first thing we use is `useImperativeHandle`. This allows us to customize methods on an object that is made available to the parents via the `useRef` API. Inside `ElaborateInput` we have two refs: one thate is the one that will be provided by the parent, forwarded through by wrapping the `ElaborateInput` component in a `forwardRef` call which will ten provide that second `ref` parameter in the function call, and then the `inputRef` which is being used to directly access the DOM so we can call `focus` on the DOM node directly. +The first thing we use is `useImperativeHandle`. This allows us to customize methods on an object that is made available to the parents via the `useRef` API. Inside `ElaborateInput` we have two refs: one that is the one that will be provided by the parent, forwarded through by wrapping the `ElaborateInput` component in a `forwardRef` call which will then provide that second `ref` parameter in the function call, and then the `inputRef` which is being used to directly access the DOM so we can call `focus` on the DOM node directly. From the parent, we assign via `useRef` a ref to each of the `ElaborateInput`s which is then forwarded on each on via the `forwardRef`. Now, on these refs inside the parent component we have those methods that we made inside the child so we can call them when we need to. In this case, we'll calling the focus when the parent knows that the child has an error.