zoukankan      html  css  js  c++  java
  • jQuery中ready与load事件的区别

    1、摘要

    大家在编程中使用jQuery还有JS的时候一定会在使用之前这样:

    //document ready
    $(document).ready(function(){
        ...code...
    })
    //document ready 简写
    $(function(){
        ...code...
    })

     有时候也这样:

    //document load
    $(document).load(function(){
        ...code...
    })

    一个是ready一个是load,这两个到底有什么区别呢?今天我们来聊一聊。

    2、ready和load谁先执行:

      大家在面试的过程中,经常会被问到一个问题:ready与load那一个先执行,那一个后执行?答案是ready先执行,load后执行。

    3、dom文档加载步骤:  

    要想理解为什么ready先执行,load后执行就要先聊一下DOM文档加载的步骤:

      (1) 解析HTML结构。

      (2) 加载外部脚本和样式表文件。

      (3) 解析并执行脚本代码。

      (4) 构造HTML DOM模型。//ready

      (5) 加载图片等外部文件。

      (6) 页面加载完毕。//load

    从上面的描述中大家应该已经理解了吧,ready在第(4)步完成之后就执行了。但是load要在第(6)步完成之后才执行。

    4、关于ready事件:

      ready事件在DOM结构绘制完成之后就绘执行。这样能确保就算有大量的媒体文件没加载出来,JS代码一样可以执行。

    5、关于load事件

      load事件必须等到网页中所有内容全部加载完毕之后才被执行。如果一个网页中有大量的图片的话,则就会出现这种情况:网页文档已经呈现出来,但由于网页数据还没有完全加载完毕,导致load事件不能够即时被触发。

    6、总结:

      相信大家已经了解了ready与load的区别,其实如果页面中要是没有图片之类的媒体文件的话ready与load是差不多的,但是页面中有文件就不一样了,所以还是推荐大家在工作中用ready。

  • 相关阅读:
    Access Update 不支持子查询 用查询解决
    vs2005中文乱码
    清理sql日志
    VS2005快捷键使用
    如何用C#改文件名
    C#中使用DirectSound录音
    VS2005打包 到没有.NETFramework2.0的目标机器上安装
    Access中iif,isnull的用法
    水晶报表切换字段视图不能用的问题。
    VS2005中TextBox的ReadOnly属性
  • 原文地址:https://www.cnblogs.com/shazhou-blog/p/5175353.html
Copyright © 2011-2022 走看看