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>
);
}