React: как визуализировать компоненты, вставленные с помощью dangerousSetInnerHTML?

Если у меня есть обычная текстовая строка, в которую я хочу вставить некоторые компоненты, как правильно это сделать?

Пример кода, codeandbox

import React, { useRef } from "react";
import ReactDOMServer from "react-dom/server";

import "./styles.css";

export default function App() {
  const testID = () => {
    document.getElementById("myId").textContent = "gotcha!";
  };
  const testUSEREF = () => {
    myRef.current.textContent = "gotcha!";
  };

  const plain_text = "<div><myPlainDiv />hey</div>";
  const myRef = useRef();
  const newContent = plain_text.replace(/<myPlainDiv \/>/, str =>
    ReactDOMServer.renderToString(
      <div>
        <div id="myId">I am using ID</div>
        <div ref={myRef}>I am using USEREF</div>
      </div>
    )
  );

  return (
    <div className="App">
      <h1>Hello CodeSandbox</h1>
      <div dangerouslySetInnerHTML={{ __html: newContent }} />
      <button onClick={testID}>click me ID</button>
      <button onClick={testUSEREF}>click me USEREF</button>
    </div>
  );
}

Я могу получить доступ к ссылке с getElementById, но если я хочу использовать myRefкак мне его использовать? И я должен его использовать?


РЕДАКТИРОВАТЬ: Это сработает, но мне интересно, правильный ли это способ, и в любом случае, почему использование простого JavaScript здесь неверно?

import React, { useRef, useEffect } from "react";
import ReactDOMServer from "react-dom/server";
import ReactDOM from "react-dom";

import "./styles.css";

export default function App() {
  const testID = () => {
    document.getElementById("myId").textContent = "gotcha!";
  };
  const testUSEREF = () => {
    myRef.current.textContent = "gotcha!";
  };

  const plain_text = `<div>
  <div id="what"></div>
  <div>hey</div>
  </div>`;
  const myRef = useRef();
  const NewContent = () => (
    <div>
      <div id="myId">I am using ID</div>
      <div ref={myRef}>I am using USEREF</div>
    </div>
  );

  useEffect(() => {
    const container = document.getElementById("what");
    ReactDOM.render(<NewContent />, container);
  }, []);

  return (
    <div className="App">
      <h1>Hello CodeSandbox</h1>
      <div dangerouslySetInnerHTML={{ __html: plain_text }} />
      <button onClick={testID}>click me ID</button>
      <button onClick={testUSEREF}>click me USEREF</button>
    </div>
  );
}

0 ответов

Другие вопросы по тегам