ホームページ >ウェブフロントエンド >jsチュートリアル >危険な方法で SetInnerHTML を使用して React で HTML 文字列を安全にレンダリングする方法

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

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-15 00:34:02454ブラウズ

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: '<p><strong>Our Opportunity:</strong></p>',
    };
  }

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

  render() {
    return (
      <div
        dangerouslySetInnerHTML={{ __html: this.htmlDecode(this.state.description) }}
      />
    );
  }
}

ReactDOM.render(<App />, document.getElementById('root'));

この例では、description プロパティに HTML エンティティ (< および >) が含まれています。正しくレンダリングするために、htmlDecode 関数を使用してこれらのエンティティをデコードしてから、HTML を危険なほど SetInnerHTML に渡します。

以上が危険な方法で SetInnerHTML を使用して React で HTML 文字列を安全にレンダリングする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。