I'm experimenting with React Hooks and I'm wondering how to target elements children with useRef. Actually, I know how to target an element with useRef. But I meet some problems when I'm trying to assign children to a variable.
Here's an example :
import React, { useState, useEffect, useRef } from "react";
import "./styles.css";
export default function App() {
  let containerRef = useRef(null);
  let title, subtitle;
  const myEvent = () => {
    console.log(title);
  };
  useEffect(() => {
    title = containerRef.children[0];
    subtitle = containerRef.children[1];
  }, []);
  return (
    <div className="App" ref={el => (containerRef = el)}>
      <h1 onClick={myEvent}>Hello World!</h1>
      <h2>What's going on ?</h2>
    </div>
  );
}
I would like to access to the title and subtitle variables to create a function outside of useEffect. I know I'm wrong about the first declaration of title and subtitle. But actually I don't know how to fix this. I tried to use useState, but I failed to resolve my problem.
(Precisions : of course, in my real project, I just don't want display the variable in the console).
Can someone help me to fix this ?
You need to target your current HTML element and then get children like:
import React, { useState, useEffect, useRef } from "react";
import "./styles.css";
export default function App() {
  let containerRef = useRef(null);
  const [title, setTitle] = useState("");
  const myEvent = () => {
    console.log(title);
  };
  useEffect(() => {
    setTitle(containerRef.current.children[0]);
  }, []);
  return (
    <div className="App" ref={containerRef}>
      <h1 onClick={myEvent}>Hello World!</h1>
      <h2>What's going on ?</h2>
    </div>
  );
}
This will log children to the console. Hope this will help you.
You can use useRef to store some object between renders:
import React, { useRef, useEffect } from "react";
import "./styles.css";
export default function App() {
  const containerRef = useRef(null);
  const titleRef = useRef(null);
  const subtitleRef = useRef(null);
  const myEvent = () => {
    console.log(titleRef.current);
  };
  useEffect(() => {
    titleRef.current = containerRef.current.children[0];
    subtitleRef.current = containerRef.current.children[1];
  }, []);
  return (
    <div className="App" ref={containerRef}>
      <h1 onClick={myEvent}>Hello World!</h1>
      <h2>What's going on ?</h2>
    </div>
  );
}
CodeSandbox: https://codesandbox.io/s/jovial-sound-e0eq2
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With