JQuery下关于$.Ready()的分析

 更新时间:2009年12月13日 02:27:21   作者:  
最近一直在研究JQuery,这个东西还是很博大精深的.下面分享一下我的学习总结.
$(document).Ready()方法 VS OnLoad事件 VS $(window).load()方法
接触JQuery一般最先学到的是何时启动事件。在曾经很长一段时间里,在页面载入后引发的事件都被加载在”Body”的Onload事件里.

对于Body的Onload事件和JQuery的Ready方法相比,有很多弊端.比如:

1.加载多个函数的问题
<body onload="a();b();">
</body>

在Onload事件中只能这样加载,很丑陋…而在JQuery中你可以利用多个JQuery.Ready()方法,它们会按次序依次执行

2.代码和内容不分离
这个貌似不用说了,让人深恶痛绝-.-!!

3.执行先后顺序不同
对于Body.Onload事件,是在加载完所有页面内容才会触发,我的意思是所有内容,包括图片,flash等.如果页面的这些内容很多会让用户等待很长时间.

而对于$(document).ready()方法,这个方法只是在页面所有的DOM加载完毕后就会触发,无疑很大的加快了网页的速度.

但是对于一些特殊应用,比如图片的放大缩小,图片的剪裁。需要网页所有的内容加载完毕后才执行的呢?我推荐使用$(window).load()方法,这个方法会等到页面所有内容加载完毕后才会触发,并且同时又没有OnLoad事件的弊端.
复制代码 代码如下:

<script type="text/javascript">
$(window).load(function() {
alert("hello");
});
$(window).load(function() {
alert("hello again");
});
</script>

上面的代码会在页面所有内容加载完成后按先后顺序依次执行.

当然不要忘了与之对应的Unload方法
复制代码 代码如下:

$(window).unload(function() {
alert("good bye");
});

上面代码会在页面关闭时引发.

在所有DOM加载之前引发JS代码
这个方法是我在调试的时候最喜欢的,有时候开发的时候也用这种方法
复制代码 代码如下:

<body>
<script type="text/javascript">
(function() {
alert("hi");
})(jQuery)
</script>
</body>

对,就是利用js闭包的形式将js代码嵌入body,这段代码会自动执行,当然也可以直接嵌入js代码,这种方式要注意顺序问题,如下:
复制代码 代码如下:

<body>
<div id="test">this is the content</div>
<script type="text/javascript">

alert($("#test").html());//I Can display the content

</script>
</body>
<body>

<script type="text/javascript">

alert($("#test").html());//I Can't display the content

</script>
<div id="test">this is the content</div>
</body>

上面两段代码,第二段代码当中因为只能解释到当前代码之前的DOM,而test并不存在于已经解析的DOM数.所以第二段代码无法正确显示.

相关文章

  • JQuery Ajax 跨域访问的解决方案

    JQuery Ajax 跨域访问的解决方案

    我们知道ajax本身实际上是通过XMLHttpRequest对象来异步进行数据的交互,而浏览器出于安全考虑,不允许js代码进行跨域操作,所以js跨域操作会被拒绝。
    2010-03-03
  • jquery 上下滚动广告

    jquery 上下滚动广告

    jquery 上下滚动广告实现代码,大家可以自行测试,需要加载jquery类库
    2009-06-06
  • jQuery为某个div加入行样式

    jQuery为某个div加入行样式

    这篇文章主要为大家详细介绍了jQuery为某个div加入行样式的相关方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 如何确保JavaScript的执行顺序 之jQuery.html深度分析

    如何确保JavaScript的执行顺序 之jQuery.html深度分析

    在上一篇文章《如何确保JavaScript的执行顺序 - 之实战篇》中,我们发现jQuery的html函数能够确保动态加载的JavaScript按照引入顺序执行。
    2011-03-03
  • jQuery实现的别踩白块小游戏完整示例

    jQuery实现的别踩白块小游戏完整示例

    这篇文章主要介绍了jQuery实现的别踩白块小游戏,结合实例形式详细分析了jQuery针对页面元素的计算、判定、动态操作相关实现技巧,需要的朋友可以参考下
    2019-01-01
  • jQuery读取本地的json文件(实例讲解)

    jQuery读取本地的json文件(实例讲解)

    下面小编就为大家带来一篇jQuery读取本地的json文件(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • jquery对象访问是什么及使用方法介绍

    jquery对象访问是什么及使用方法介绍

    这篇文章主要为大家详细介绍了jquery对象访问是什么及使用方法介绍,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • jQuery实现鼠标移入显示蒙版效果

    jQuery实现鼠标移入显示蒙版效果

    这篇文章主要为大家详细介绍了jQuery实现鼠标移入显示蒙版效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • jquery div 居中技巧应用介绍

    jquery div 居中技巧应用介绍

    在项目实战中碰到了一些问题,例如,jquery如何使div居中,此问题一直困扰着我,因此寻找了一些方法,晒出来和大家分享一下
    2012-11-11
  • 载入jQuery库的最佳方法详细说明及实现代码

    载入jQuery库的最佳方法详细说明及实现代码

    网站开发的项目中使用Google CDN的jQuery库虽然加载速度很快,但调用本地服务器的库才可以确保万无一失,接下来介绍载入jQuery库的最佳方法,感兴趣的朋友可以研究下
    2012-12-12

最新评论