

こんにちは。DOMについては全く無知です。
このようなのを作ったところ、google chromeでは動いたものの、ieでは動きませんでした。
var iBody = $("hoge").contentWindow.document.getElementsByTagName("body")[0];
var newText = document.createElement("div");
newText.innerHTML = "aaa";
iBody.appendChild(newText);
※$("hoge")は、iframeタグを指しています
いろいろ試したところ、ieだとフレーム内にアクセスすることができないみたいです。
どうすればいいのか、ご存知でしたらご教示願います。
No.4
- 回答日時:
#1,2,3です。
いろいろと勘違いしていまして、#3はIEでは動きません。
当方の確認不足でした。申し訳ありません。
下記コードは
http://www.bit-hive.com/~tomita/JS/IframeAppend/
を参考にして、IE7,Firefox3で動作確認しました。
<iframe id='B' src='B.html'></iframe>
<script type='text/javascript'>
(function(){
var iframeId = 'B';
var b = document.getElementById(iframeId);
b.onload = function(){
var idoc;
if (document.all) {// IEなら
idoc = frames[iframeId].document;
} else {
idoc = b.contentDocument;
}
var div = idoc.createElement("div");
div.appendChild(idoc.createTextNode('It is a test.'));
idoc.body.appendChild(div);
}
})();
</script>
No.3
- 回答日時:
#1,2です。
すみません、#2 は質問の意を取り違えていました。
appendChildするのはiframe内なのですね。
下記コードでOKだと思います。(確認済み)
<iframe id='B' src='B.html'></iframe>
<script type='text/javascript'>
(function(){
var b = document.getElementById('B');
b.onload = function(){
var body = this.contentDocument.getElementsByTagName("body")[0];
var div = document.createElement("div");
div.appendChild(document.createTextNode('It is a test!'));
body.appendChild(div);
}
})();
</script>
No.2
- 回答日時:
簡易HTMLを作って検証して、下記コードで期待通りの動作を得られました。
<iframe id='B' src='B.html' style='display:none;'></iframe>
<script type='text/javascript'>
(function(){
var b = document.getElementById('B');
b.onload = function(){
var body = this.contentDocument.getElementsByTagName("body")[0];
document.body.appendChild(body);
}
})();
</script>
iframeが読み込まれない内にbodyを読み込もうとして失敗しているのかもしれません。
ベースに下記Q&Aのコードがあったので、そこから借用。(自分のコードですが)
window.onload ではなく、iframe.onload を使ったところだけ違います。
別画面の関数の呼び出し -OKWave
http://okwave.jp/qa4988613.html?ans_count_asc=1
No.1
- 回答日時:
もうちょっと現象を再現できる情報が欲しいですね…。
- '$("hoge")...' を回答者側で実行可能なように(ライブラリの開示、もしくはライブラリ依存をなくしたコードに修正)
- HTMLの掲示
はできないでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<a>タグのテキストを取得
-
ActiveXobjectが作成できない
-
javascriptで編集可能不可能の...
-
日本語入力の禁止
-
Strutsで半角英数字1文字以上
-
Vb.netのグローバル変数の宣言...
-
関数でy=g(x)のgとは何の略です...
-
翌月を取得するGASが分かりません
-
JavaScriptで、現在日時から100...
-
cgiでポーリングして取得したデ...
-
java scriptでの表示件数の制御...
-
同じIDで定義した要素の配列を...
-
window.openでタイトル名の指定
-
javascriptでテーブルに追加し...
-
ASP.NET MVCでObjectをjsに渡す
-
ブラウザ、OSによってCSSを使い...
-
JavaScriptで年月日表示のカウ...
-
VC++のちらつき防止方法
-
【正規表現】【javascript】CR...
-
アルファベットABCD…をスマート...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ActiveXobjectが作成できない
-
<a>タグのテキストを取得
-
onchangeイベントを使ってspan...
-
javascriptで編集可能不可能の...
-
innerHTML実行後のイベント
-
javascriptの質問です
-
クリックでURLに飛ばすときに、...
-
ボタン上でマウスを押している...
-
別フレームのタグ属性を取得す...
-
DIV内のDIV要素を移動する。
-
HTML:Tableタグに対し、JavaScr...
-
任意の座標をクリックさせるには
-
お気に入り用のボタンを配置し...
-
1つの処理で複数表示させたい
-
WordPressのコンタクトフォーム...
-
指定した数値同士を合計計算し...
-
JavaScriptで文字列の置き換え
-
フォーカスを合わせる
-
div要素内の全input要素をdisable
-
[javascript]DOCTYPE宣言対応に...
おすすめ情報