JQuery onload、ready概念介绍及使用方法

 更新时间:2013年04月27日 16:15:13   作者:  
页面加载完成有两种事件,一是ready,表示文档结构已经加载完成,onload,ready概念容易混淆,下面为大家详细介绍下
页面加载完成有两种事件,一是ready,表示文档结构已经加载完成(不包含图片等非文字媒体文件),二是onload,指示页 面包含图片等文件在内的所有元素都加载完成。(可以说:ready 在onload 前加载!!!)
一般样式控制的,比如图片大小控制放在onload 里面加载;

jS事件触发的方法,可以在ready 里面加载;
用jQ的人很多人都是这么开始写脚本的:
通常的写法
复制代码 代码如下:

$(function(){
// do something
});

其实这个就是jq ready()的简写,他等价于:
复制代码 代码如下:

$(document).ready(function(){
//do something
})

也等于下面这个方法,jQuer的默认参数是:“document”;
复制代码 代码如下:

$().ready(function(){
//do something
})

$(document).Ready()方法 VS OnLoad事件 VS $(window).load()方法
接触JQuery一般最先学到的是何时启动事件。在曾经很长一段时间里,在页面载入后引发的事件都被加载 在”Body”的Onload事件里.
对于Body的Onload事件和JQuery的Ready方法相比,有很多弊端.比如:
加载 多个函数的问题
■<body onload="a();b();">
</body>
在Onload事件中 只能这样加载,很丑陋…
■而在JQuery中你可以利用多个JQuery.Ready()方法,它们会按次序依次执行
代码和内容不分离
这个貌似不用说了,让人深恶痛绝-.-!!◦ 执行先后顺序不同
■对于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方法
复制代码 代码如下:

<script type="text/javascript">
$(window).unload(function() {
alert("good bye");
});
</script>

上面代码会在页面关闭时引发.
在 所有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 表单进行客户端验证demo

    jquery 表单进行客户端验证demo

    用jquery对表单进行客户端验证demo ,学习jquery的朋友可以参考下。
    2009-08-08
  • 图标线性回归斜着移动到指定的位置

    图标线性回归斜着移动到指定的位置

    图标斜着移动到指定的位置如何实现,本文给予了详细的解决方法,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • EasyUI学习之DataGird分页显示数据

    EasyUI学习之DataGird分页显示数据

    这篇文章主要介绍了EasyUI学习之DataGird分页显示数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • jQuery表格列宽可拖拽改变且兼容firfox

    jQuery表格列宽可拖拽改变且兼容firfox

    使用jQuery包,实现表格列宽可拖拽功能,并实现页面reset时的重新布局,用法及示例如下,感兴趣的朋友不要错过
    2014-09-09
  • javascript的变量、传值、传址、参数之间关系

    javascript的变量、传值、传址、参数之间关系

    这篇文章主要介绍了javascript的变量、传值、传址、参数之间关系的相关资料,需要的朋友可以参考下
    2015-07-07
  • Jquery判断IE6等浏览器的代码

    Jquery判断IE6等浏览器的代码

    jquery中利用navigator.userAgent.indexOf来判断浏览器类型,并进行了一下处理,如果不想使用jquery,稍为修改下代码就可以为自己所用
    2011-04-04
  • jquery中map函数遍历数组用法实例

    jquery中map函数遍历数组用法实例

    这篇文章主要介绍了jquery中map函数遍历数组用法,实例分析了jQuery中map函数遍历数组的相关技巧,并提供了一个自定义遍历数组函数供参考之用,需要的朋友可以参考下
    2015-05-05
  • jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法

    jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法

    这篇文章主要介绍了jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法,结合实例形式分析了属性插件zTree针对节点序号的相关操作技巧,需要的朋友可以参考下
    2017-03-03
  • jQuery使用children()找到特定元素的子元素

    jQuery使用children()找到特定元素的子元素

    children()是jQuery中的内置方法,用于查找与所选元素相关的所有子元素, jQuery中的children()方法向下遍历到所选元素的单个级别并返回所有元素,我们还可以在children()的参数中添加过滤器、使用children()来定位特定的子元素以及使用each()方法来迭代子元素等
    2023-11-11
  • JQuery学习总结【一】

    JQuery学习总结【一】

    本文主要介绍了JQuery的基本知识,如:jquery内置函数,JQuery对象,Dom对象,jquery选择器,jquery的迭代,jquery的节点遍历等等,有助于对JQuery基本知识的学习与巩固。需要的朋友可以参考下
    2016-12-12

最新评论