2016-11-15 27 views
2

的document.ready功能我想学习jQuery和我感到困惑多么的document.ready()函数的工作jQuery的:为什么不能正常工作

$(document).ready(function(){} 

在HTML中,

<script type="text/javascript" src="jquery.js"></script> 
<script src="script.js" type="text/javascript"></script> 

链接位于文档的最底部,就在结束标签之前。在我的javaScript文件中,我有我的所有代码在.ready函数中。然而,当我加载页面,并且将鼠标悬停在链接上时,我的光标在几秒钟内不会变成指针,如果我立即向下滚动,文本还没有加载几秒钟, 。 我的javaScript文件有一堆iframe等...所以我可以理解为什么延迟,但让我困惑的是,我认为.ready函数的全部内容是,直到所有其他页面首先被加载?所以我的文本和我的CSS应该马上工作吗?这是我的代码,如果它有帮助。如果需要,我也可以发布css。

<!DOCTYPE html> 
<html> 
<head> 
    <meta charset="UTF-8"> 
    <title>myPage</title> 
    <link rel="stylesheet" type="text/css" href="styles2.css"> 

</head> 
<body> 

<div id="container"> 

<div id="backgroundLeft"><img id='backgroundLeftImage' src="Left.jpg" width="100%"></div> 

<div id="wrap"> 

<p id="text">...some text... <span id="firstLink" class="link">click me</span>.<span><iframe id="frame" class="rect" scrolling="no" marginwidth=0 marginheight=0></iframe> 

</span> ...some more text.... <span id="secondLink" class="link">click me</span>, 
</span><span> 
    <iframe id="frame2" class="rect" scrolling="no" marginwidth=0 marginheight=0></iframe> 
</span> 
... some more text... <span id="thirdLink" class="link">click me</span> </span><span> 
    <iframe id="frame3" class="rect" scrolling="no" marginwidth=0 marginheight=0></iframe> 
</span> ... some more text... 

ETC... 

</p> 

</div> 

<div id="backgroundRight"><a href="index2.html"><img id='backgroundRightImage' src="2VillesRight.jpg" width="100%"></a></div> 

    <script type="text/javascript" src="jquery.js"></script> 
    <script src="script2.js" type="text/javascript"></script> 
</body> 
</html> 

JS

$(document).ready(function(){ 

    var frame = $("#frame"); 
    frame.attr("src","iframe.html"); 
    var frame2 = $("#frame2"); 
    frame2.attr("src","iframe2.html"); 
    var frame3 = $("#frame3"); 

etc... 

     var player; 

     frame.bind("load", function() { 
      player = $(this).contents().find("#firstVid"); 
      player.on('ended', function() { 
       frame.removeClass("open"); 
      }); 
     }); 

     $("#firsLink").click(function(){ 
      if (frame.hasClass("open")) 
      { 
       frame.removeClass("open"); 
       player[0].pause(); 
      } 
      else { 
       frame.addClass("open"); 
       player[0].play(); 
      } 
     }); 

     var player2; 

     frame2.bind("load", function() { 
      player2 = $(this).contents().find("#sylvainVid"); 
      player2.on('ended', function() { 
       frame2.removeClass("open"); 

      }); 
     }); 

     $("#secondLink").click(function(){ 
      if (frame2.hasClass("open")) 
      { 
       frame2.removeClass("open"); 
       player2[0].pause(); 
      } 
      else { 
       frame2.addClass("open"); 
       player2[0].play(); 
      } 
     }); 

     var player3; 

     frame3.bind("load", function() { 
      player3 = $(this).contents().find("#etienneVid"); 
      player3.on('ended', function() { 
       frame3.removeClass("open"); 

      }); 
     }); 

     $("#thirdLink").click(function(){ 
      if (frame3.hasClass("open")) 
      { 
       frame3.removeClass("open"); 
       player3[0].pause(); 
      } 
      else { 
       frame3.addClass("open"); 
       player3[0].play(); 
      } 
     }); 

etc... 
}); 

我知道我的代码是重复的,我在自修太专注于得到它现在的工作。为什么我的主页花了这么长时间来加载,如果我所有的代码都在“document.ready”中?感谢您的时间

+1

这是一般的想法。但在评论之前,有必要查看更多的页面html。请张贴页面。 –

回答

5

您可以将您的JavaScript绑定,而不是像这样

$(window).load(function(){ ... }); 

文件准备好window.load事件使您可以访问完整的标记,即使图像和iframe中尚未加载,这在大多数情况下是期望的。

然而,在你的情况下,你可能想要等待一切加载的时间惩罚,这是window.load事件。

+0

同意。我也会提到这一点。 –

+0

当我将我的jQuery代码包装在$(window).load(function(){...})中时;这些链接根本不起作用 – Paul

+0

@Paul你可能需要在'$(document).ready()'中放置一些代码,'$(window).load()'内的一些代码,以及甚至可能在'$(“#frame”).load()'内部有一些代码,这取决于在加载标记后是否需要执行代码,只要加载所有iframe和图像,或者尽快作为一个特定的iframe被加载,分别 –

0

$(document).ready()只会等待所有页面的元素加载。它不会等待iFrame加载其内容。

你可以参考这篇文章,如果您有更多问题:

$(document).ready and iframe content

0

你肯定jQuery是正确加载?源(src)属性需要指向正确的路径。我发现使用开发人员的工具来查看错误,操作CSS并检查DOM状态对学习有帮助。我更喜欢Chrome