• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:実行の順番を教えて下さい。)

jQueryの実行順番と丸括弧の意味について

このQ&Aのポイント
  • jQueryの実行順番と丸括弧の意味について説明します。
  • 上記の処理では、jQuery1.7.1をロードして後、jQuery1.2.3をロードしていますが、(1)のところで、jQuery1.7.1を保持し、(2)で再び$とjQuery変数にロードしているため(3)のところで、'1.7.1'と表示されます。
  • クロージャーなどで、(function(){})() と記述しますが、function(){}を式として認識させるために丸括弧で囲っているのは、関数を即時に実行するためです。今回の処理でも同様の意味を持っています。

質問者が選んだベストアンサー

  • ベストアンサー
  • dscripty
  • ベストアンサー率51% (166/325)
回答No.2

[ANo.1] の補足への回答ね。 > $()で囲まれていれば DOMが完成したときと理解できるのですが、 > 囲まれていないのに、DOMが完成したときに呼 > ばれるのはなぜなのでしょうか?? 『$() 囲んである関数は、DOM が完成したときによばれる。』 ではなくて。 『jQuery オブジェクト() で囲んである関数は、DOM が完成したときによばれる。』 だから $(関数); //と書いても jQuery(関数); //と書いても (tmp_jquery=jQuery)(関数); //と書いても DOM が完成したときに関数がよばれる。 という説明でよさそう?

1qaz_2wsx
質問者

お礼

なるほど、そう言うことだったんですね! ガッテンしました。 詳細な説明ありがとうございました。 感謝しています。

その他の回答 (1)

  • dscripty
  • ベストアンサー率51% (166/325)
回答No.1

前提 - 式は評価後すぐ実行される - 関数は評価後、関数を呼び出す式が評価されて初めて実行される - 関数を呼び出す式の評価は、始めに引数が評価されて   そのあと関数の中の式が順に評価される。 - $(関数); と jQuery(関数); は   $(document).bind("ready", 関数); の簡略構文で、   この機能は document の DOM が完成したときに   「関数」が呼び出されるように予約しておくというもの。   つまり $(関数); の関数はその時点では評価されるだけで、   呼び出されるのは document の DOM が完成したとき。 下のコードの中の左端にある「(数字).」は評価順序。 1...<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script> ....<script type="text/javascript"> 4...( 4.2.  tmp_jquery=jQuery;// ……(1) 4...)( 4.3.  function(){ 4.3.    $=jQuery=tmp_jquery;// ……(2) 4.3.  } 4...); ....</script> 5...<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.3/jquery.min.js"></script> ....<script> 7...$( 7.6.  function(){ 7.6.    alert(jQuery.fn.jquery);// ……(3) 7.6.  } 7...); ....</script> 机上デバッグ開始。 1.で jQuery や $ が jQuery 1.7.1 へ。 2.は式なのですぐ実行される。tmp_jquery は jQuery 1.7.1 3.は 4.(関数を呼び出す式) の引数なので、すぐに評価されるけれど、関数なので呼び出されるまで実行されない。呼び出されるのは DOM が完成したとき。 5.で jQuery や $ が jQuery 1.2.3 へ。 6.は 7.(関数を呼び出す式) の引数なので、すぐに評価されるけれど、関数なので呼び出されるまで実行されない。呼び出されるのは DOM が完成したとき。 (HTML が最後まで読み込まれて DOM が完成する) 3.が呼び出されて ……(2) が評価される。式なのですぐに実行されて $ と jQuery は jQuery 1.7.1 6.が呼び出されて ……(3) が評価される。alert 関数を呼び出して jQuery 1.7.1 の jQuery.fn.jquery が表示される。 机上デバッグ終了。

1qaz_2wsx
質問者

お礼

詳細な説明ありがとうございます。

1qaz_2wsx
質問者

補足

詳細な解説ありがとうございます。 ただ、3.が実行されるのが「DOMが完成したとき。」と言うのが 理解できません。 例えば、 (式)(function(){$=jQuery=tmp_jquery;}); が (式)($(function(){$=jQuery=tmp_jquery;}));のように $()で囲まれていれば DOMが完成したときと理解できるのですが、 囲まれていないのに、DOMが完成したときに呼ばれるのはなぜなのでしょうか?? 実行時の挙動を見ると説明して頂いたとおりだと思います。 ただ、私頭が弱いので、どうしても納得できないのです・・・。 ごめんなさい。

関連するQ&A

専門家に質問してみよう