ブランクのブログ: http://www.planabc.net/ innerHTML プロパティは、HTML 要素の内容を完全に置き換える簡単な方法を提供するため、非常によく使用されます。別の方法としては、DOM レベル 2 API (removeChild、createElement、appendChild) を使用する方法があります。しかし、innerHTML を使用して DOM ツリーを変更するのは非常に簡単で効果的な方法であることは明らかです。ただし、innerHTML には独自の問題があることに注意する必要があります。
他にも言及する価値のある小さな欠点がいくつかあります。
私は、innerHTML プロパティの使用に関連するセキュリティとメモリの問題をより懸念しています。明らかに、これらは新しい問題ではなく、すでにこれらの問題のいくつかを回避する方法を考え出した賢明な人々がいます。 Douglas Crockford 氏は、HTML 要素に登録されたイベント ハンドラーによって発生する循環参照を解消し、ガベージ コレクターがこれらの HTML 要素に関連付けられたメモリを解放できるようにするクリーンアップ関数を作成しました。 HTML 文字列からスクリプト タグを削除するのは、見た目ほど簡単ではありません。正規表現は期待どおりの動作をする可能性がありますが、すべての可能性がカバーされているかどうかを知ることは困難です。これが私の解決策です: /<script[^>]*>[\S\s]*?<\/script[^>]*>/ig ここで、これら 2 つの手法を 1 つの setInnerHTML 関数に組み合わせ、setInnerHTML 関数を YUI の YAHOO.util.Dom にバインドしてみましょう。 YAHOO.util.Dom.setInnerHTML = 関数 (el, html) { el = YAHOO.util.Dom.get(el); if (!el || typeof html !== 'string') { null を返します。 } // 循環参照を解除する (関数 (o) { var a = o.attributes、i、l、n、c; もし(a){ l = a.長さ; (i = 0; i < l; i = 1) の場合 { n = a[i].名前; if (typeof o[n] === 'function') { o[n] = null; } } } o.childNodes を継承します。 もし(a){ l = a.長さ; (i = 0; i < l; i = 1) の場合 { c = o.childNodes[i]; // 子ノードをクリアする 引数.callee(c); // YUI の addListener を通じて要素に登録されたすべてのリスナーを削除します YAHOO.util.Event.purgeElement(c); } } })(エル); // HTML文字列からスクリプトを削除し、innerHTMLプロパティを設定します el.innerHTML = html.replace(/<script[^>]*>[\S\s]*?<\/script[^>]*>/ig, ""); // 最初の子ノードへの参照を返す el.firstChild を返します。 }; この関数に必要な他のものがある場合、または正規表現に何か不足しているものがある場合は、お知らせください。 明らかに、Web ページに悪意のあるコードを挿入する方法は他にもたくさんあります。 setInnerHTML 関数は、すべての A グレード ブラウザーでのみ <script> タグの実行動作を正規化します。信頼できない HTML コードを挿入する予定がある場合は、まずサーバー上でフィルタリングするようにしてください。これを実行できるライブラリは多数あります。 元記事: Julien Lecomte による innerHTML の問題 |
>>: Dockerコンテナ内で2つのプロセスを開始するときのDockerfile実装コード
まず、PHP5をインストールするのはとても簡単ですyum install php PHP5 を使用し...
目次1. データベース操作2. データ型3. バックアップとリカバリ3. 操作4. 上級5. 知識補...
この記事の例では、コンピュータカメラを呼び出して写真機能を実現するためのvueの具体的なコードを参考...
私はコーディングが大好きです。コーディングすると幸せになります!みなさんこんにちは、Counterで...
目次主キーインデックス頻繁にクエリされるフィールドのインデックスを作成する大きなフィールドのインデッ...
目次序文背景実施計画の考え方js ストレージ機能ソリューション設計やっと要約する序文どの SaaS ...
1. MySQLイメージを取得する docker pull mysql:5.6注: mysql5.7...
目次それを覆う栗パラメータの受け渡し値渡し共同配送要約する拡張機能 - 遅延評価私は最近、JavaS...
MySQL テーブルのテーブル構造をすばやく変更する - 「MySQL 管理」から抜粋 ALTER ...
目次2. 試した方法2.1 キープアライブ2.2 ネストされたルートを持つ CSS 3. 機能説明4...
目次1. Compose の紹介2. ComposeとDockerの互換性3. Dockerをインス...
序文MySql で主キーの競合または一意キーの競合が発生した場合、挿入方法に応じてエラーを回避するた...
この記事の例では、テーブルのシームレスなスクロールを実現するためのjQueryの具体的なコードを参考...
目次1. 要素の表示と非表示を制御する show() hide() 2. 要素の透明度を制御する f...
1. プラグインを追加し、pomファイルの下に次の設定を追加します。 <!-- mybatis...