[解決済み】innerHTMLでスクリプトを挿入することは可能ですか?
2022-04-04 14:28:04
質問
を使用して、いくつかのスクリプトをページに読み込もうとしました。
innerHTML
の上に
<div>
. スクリプトは DOM に読み込まれるようですが、実行されることはありません (少なくとも Firefox と Chrome では)。で挿入したときにスクリプトが実行されるようにする方法はありますか?
innerHTML
?
サンプルコードです。
<!DOCTYPE html>
<html>
<body onload="document.getElementById('loader').innerHTML = '<script>alert(\'hi\')<\/script>'">
Shouldn't an alert saying 'hi' appear?
<div id="loader"></div>
</body>
</html>
解決方法は?
を使用する必要があります。 eval() は、DOMテキストとして挿入したスクリプトコードを実行するために使用します。
MooTools は自動的にこれを行いますし、jQuery も同様でしょう (バージョンによりますが、jQuery バージョン 1.6 以上では、以下のようになります。
eval
). これによって
<script>
タグを使ったり、コンテンツをエスケープしたり、他にもいろいろなことができます。
一般的に、もしあなたが
eval()
のようなHTMLマークアップを行わずにスクリプトコードを作成/送信したい場合。
<script>
というのは、これらは
eval()
を適切に実行します。
関連
-
[解決済み】PhantomJS 2.1.1を使用してReactJSアプリケーションをレンダリングできない理由とは?
-
[解決済み] 配列から特定の項目を削除するにはどうすればよいですか?
-
[解決済み] jQueryでチェックボックスに "checked "を設定する
-
[解決済み] JavaScriptで空文字列/未定義文字列/null文字列をチェックするにはどうすればよいですか?
-
[解決済み] JavaScriptで要素のクラスを変更するにはどうすればよいですか?
-
[解決済み] どのラジオボタンが選択されているかをjQueryで知るにはどうしたらよいですか?
-
[解決済み] jQueryでページを更新するにはどうすればよいですか?
-
[解決済み] jQueryで名前を指定して要素を選択するには?
-
[解決済み] jQueryを使用してdivのinnerHTMLを置き換えるには?
-
[解決済み】HTML5入力のプレースホルダの色をCSSで変更する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Heroku:ノードアプリで「このアプリにはデフォルトの言語が検出されませんでした」エラーがスローされる
-
[解決済み】このエラーの原因は何ですか - "Fatal error: ローカルgruntを見つけることができません"
-
[解決済み】Uncaught TypeError: nullのプロパティ'value'を読み取ることができない
-
[解決済み】Angular JS Uncaught Error。[インジェクター:モジュラー]。
-
[解決済み】別のjsファイル内でJavaScriptの関数を呼び出す
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】リソースはドキュメントと解釈されるが、MIMEタイプはapplication/zipで転送される
-
[解決済み】TypeError: res.status は関数ではありません。
-
[解決済み】Uncaught ReferenceError。Firebase は定義されていません。
-
[解決済み] Uncaught (in promise) TypeError: フェッチに失敗してCorsエラー