質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

2回答

2205閲覧

動的にロードされたjsで生成されたDOMを任意の場所にアペンドするには。

ikki57

総合スコア290

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

2クリップ

投稿2015/11/25 10:38

編集2015/11/26 00:59

概要

動的にロードしたjs(非同期)の、レスポンス結果のDOMを任意の場所にアペンドしたい。

現象

非同期で処理される為、DOMのアペンド先が意図した場所にならない。

コード

html

1 <div> 2 // ここにレスポンスで返ってきたDOMを付与したい 3 <script src="script.js"></script> 4 </div>

script.js

javascript

1 var currentScript = $('script').last(); 2 var response = $('<script src="http://example.com/response.js"></script>'); 3 currentScript.after(response);

response.js

javascript

1// 何かしらの処理があり、DOMが生成されるとする。下記、テストDOM 2var elm = document.createElement('div'); 3var textNode = document.createTextNode ('this is additional DOM'); 4elm.id = 'additional'; 5elm.appendChild(textNode); 6 7// 現scriptタグの直前に、上記の生成されたDOMをアペンドする 8var current = document.currentScript; 9current.parentNode.insertBefore(elm, current) 10 11console.log('current: ', current) 12console.log('current.parentNode: ', current.parentNode) 13// ⇛ 非同期に処理が進むため、current.parentNode が 14// 期待する <div> ではなく <head> を指してしまう

結果

イメージ説明

<head>にDOMがアペンドされてしまう。


以上になります。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Lhankor_Mhy

2015/11/25 11:10

質問とは関係ないですが、ドメインが見えていますが問題ありませんか?
ikki57

2015/11/25 14:53

ご連絡ありがとうございます。 一旦スクショは削除しました。
guest

回答2

0

response.js の
var current = document.currentScript;

var current = currentScript.get(0);
に変えた時の動作は望んだものですか?

投稿2015/12/09 06:59

tozjp

総合スコア790

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

全然動作確認していないので申し訳ないのですが、script.jsを呼んでいるscript要素にdefer属性を付けると上手くいったりしませんか?

投稿2015/11/25 11:13

Lhankor_Mhy

総合スコア36057

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ikki57

2015/11/27 01:19

ご連絡ありがとうございます。 試してみた所、`defer`属性では解決できませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問