• jQuery中ready与load事件的区别


    概述:

    大家在工作中用jQuery的时候一定会在使用之前这样:
    //document ready
    $(document).ready(function(){
    ...code...
    })
    //document ready 简写
    $(function(){
    ...code...
    })

    有些时候也会这么写:

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

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

    ready与load谁先执行:

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

    DOM文档加载的步骤:

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

    (1) 解析HTML结构。
    (2) 加载外部脚本和样式表文件。
    (3) 解析并执行脚本代码。
    (4) 构造HTML DOM模型。//ready
    (5) 加载图片/css/音频等外部文件。
    (6) 页面加载完毕。//load

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

    ready事件:

    1. ready事件在DOM结构绘制完成之后就绘执行。这样能确保就算有大量的媒体文件没加载出来,JS代码一样可以执行。
    2. ready事件可以被多处绑定,所有的处理函数都可以被执行。

    load事件:

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

    总结:

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

    Chrome不能获取图片高度的问题

    大家遇没遇到过在chrome中,在用jQuery的ready事件的时候想要获取页面中图片的高度是获取不到的?
    $(document).ready(function(){
      $("#img").height();//在chrome中获取到为0;
    })

    解决方法:

    其实解决方法也很简单,把ready事件换为load事件就可以了。
    $(window).load(function(){
      $("#img").height();//在chrome中可以获取到
    })
  • 相关阅读:
    ORACLE【0】:基本操作
    ORACLE【3】:分区表以及分区索引
    ORACLE【2】:锁机制及解锁
    log4j学习一:解决系统日志错位问题
    使用一个非堵塞的socket用于接收http请求
    Python中文转换报错 'ascii' codec can't decode byte 0xe8 in position
    首次使用Redis记录【3】
    xsi:schemaLocation有何作用
    【转】【redis】3.Spring 集成注解 redis 项目配置使用
    maven仓库地址
  • 原文地址:https://www.cnblogs.com/SherryIsMe/p/4752446.html
Copyright © 2020-2023  润新知