「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 危険な方法で SetInnerHTML を使用して React で HTML 文字列を安全にレンダリングする方法

危険な方法で SetInnerHTML を使用して React で HTML 文字列を安全にレンダリングする方法

2024 年 11 月 18 日に公開
ブラウズ:541

How to Safely Render HTML Strings in React Using dangerouslySetInnerHTML?

HTML 文字列を HTML として安全にレンダリングする

このシナリオでは、HTML コンテンツの通常の文字列をレンダリングしようとすると問題が発生しますが、代わりに、HTML として解釈されずに文字列として表示されます。これは通常、dangerouslySetInnerHTML で使用されているプロパティが文字列ではなくオブジェクトである場合に発生します。

これを解決するには、this.props.match.description プロパティが文字列であることを確認してください。そうでない場合は、プロパティに割り当てる前に HTML に変換します。

HTML エンティティの処理

HTML エンティティを処理する場合、さらに複雑な問題が発生します。このような場合、エンティティを危険なほどSetInnerHTMLに渡す前にデコードする必要があります。

コード例

次のコード例を考えてみましょう:

class App extends React.Component {
  constructor() {
    super();
    this.state = {
      description: '

Our Opportunity:

', }; } htmlDecode(input) { const e = document.createElement('div'); e.innerHTML = input; return e.childNodes.length === 0 ? '' : e.childNodes[0].nodeValue; } render() { return (
); } } ReactDOM.render(, document.getElementById('root'));

この例では、description プロパティに HTML エンティティ () が含まれています。正しくレンダリングするには、HTML を危険なほど SetInnerHTML.

に渡す前に、htmlDecode 関数を使用してこれらのエンティティをデコードします。
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3