资源载入和页面事件

理想的页面载入方式

  1. 解析HTML结构。
  2. 载入并解析外部脚本。
  3. DOM树构建完成,运行脚本。//DOMInteractive –> DOMContentLoaded
  4. 载入图片、样式表文件等外部文件。

  5. 页面载入完成。//window.onload

涉及到的事件

  1. window.onload:

    当页面全部载入完成(包含全部资源)

  2. document.onload:

    当整个html文档载入的时候就触发了。也就是在body元素载入之前就開始运行了

  3. DOMContentLoaded:

    当页面的DOM树解析好而且须要等待JS运行完才触发

    DOMContentLoaded事件不直接等待CSS文件、图片的载入完成

  4. onreadytstatechange:

    当对象状态变更时触发这个事件,一旦document的readyState属性发生变化就会触发

defer和async

  1. 没有defer和async

    浏览器会马上载入并运行指定的脚本,不等待兴许载入的文档元素,读到就载入并运行。

    当载入脚本时会堵塞页面的渲染。

  2. 有async

    载入和渲染兴许文档元素的过程将和脚本的载入与运行并行进行。体现出来就是异步。

    async JS一旦下载好了就会运行,所以非常有可能不是依照原本的顺序来运行的。

    假设脚本前后有依赖性。用async。就非常有可能出错。

  3. 有defer

    载入兴许文档元素的过程将和脚本的载入并行进行。

    可是脚本的运行要在全部元素解析完成之后。DOMContentLoaded事件触发之前完成。

    defer JS在DOMInteractive后运行。一旦运行完defer JS。就会触发DOMContentLoaded。

    也就是说defer脚本总是在DOMInteractive事件与DOMContentLoaded事件之间的时间运行。

    defer JS在html页面解析完成之后再去运行,也就是相似于把这个脚本放在了页面底部。

DOM的载入与解析

  1. DOMLoading

    浏览器開始解析dom树的时间点

  2. DOMInteractive

    表示浏览器已经解析好dom树了。

  3. DOMContentLoaded

    同步的JS已经运行完成了。


load的实现

作用:监控整个文档(包含资源)是否载入完成。全部资源载入完成后触发

原生js写法:

window.onload = function(){

}

jquery写法:

$(document).load(function(){

});

document.ready的实现

作用:监控dom是否载入完成,dom载入完成时及资源载入之前触发

原生js写法:

document.ready = function(callback) {
if (document.addEventListener) {
document.addEventListener('DOMContentLoaded', function() {
document.removeEventListener('DOMContentLoaded', arguments.callee, false);
callback();
}, false);
}else if (document.attachEvent) {// 兼容ie
document.attachEvent('onreadytstatechange', function() {
if (document.readyState == "complete") {
document.detachEvent("onreadystatechange", arguments.callee);
callback();
}
});
}
}

下面为jquery的写法:

$(function(){

});

$(document).ready(function(){

});

//jquery中默觉得document对象
$().ready(function(){ });

资源载入和页面事件 load, ready, DOMContentLoaded等的更多相关文章

  1. 再谈DOMContentLoaded与渲染阻塞—分析html页面事件与资源加载

    浏览器的多线程中,有的线程负责加载资源,有的线程负责执行脚本,有的线程负责渲染界面,有的线程负责轮询.监听用户事件. 这些线程,根据浏览器自身特点以及web标准等等,有的会被浏览器特意的阻塞.两个很明 ...

  2. WEB页面的生命周期,DOMContentLoaded,load,beforeunload,unload

    简言 理解WEB页面的生命周期,文档加载事件及顺序对WEB开发有十分的重要意义.如果不理解,在元素未加载就提前操作元素,则得不到想要的结果.而如果页面完全加载完成后,再进行操作,则又会影响用户体验. ...

  3. onload事件属性,JQ中的load,ready方法

    onload事件属性,JQ中的load,ready方法 前言 页面中的很多操作,需要我们在所需资源下载完成后,才可以进行操作,而资源没有及时下载,我们进行操作的话,是会报错.因此我们需要熟练掌握哪些事 ...

  4. 页面事件(Init,Load,PreRender)执行顺序

    简介 对由 Microsoft® Internet 信息服务 (IIS) 处理的 Microsoft® ASP.NET 页面的每个请求都会被移交到 ASP.NET HTTP 管道.HTTP 管道由一系 ...

  5. 控制使用jquery load()方法载入新页面中的元素

    最近在项目中用到jquery的load()方法来加载页面,首先简单说一下load()方法. load(url,data,callback);该方法接收三个参数,第一个是载入的页面地址,第二个是要传到服 ...

  6. 关于asp.net中页面事件加载的先后顺序

    一.ASP.NET 母版页和内容页中的事件 母版页和内容页都可以包含控件的事件处理程序.对于控件而言,事件是在本地处理的,即内容页中的控件在内容页中引发事件,母版页中的控件在母版页中引发事件.控件事件 ...

  7. asp.net页面事件执行顺序

    转自http://www.cnblogs.com/hnlyh/articles/4230388.html C#代码 using System; using System.Data; using Sys ...

  8. jQuery document window load ready 区别详解

    用过JavaScript的童鞋,应该知道window对象和document对象,也应该听说过load事件和ready事件,小菜当然也知道,而且自认为很了解,直到最近出了问题,才知道事情并不是那么简单. ...

  9. jQuery Mobile 页面事件

    jQuery Mobile 页面事件 在 jQuery Mobile 中与页面打交道的事件被分为四类: Page Initialization - 在页面创建前,当页面创建时,以及在页面初始化之后 P ...

随机推荐

  1. 洛谷 P2374 搬运工

    P2374 搬运工 题目背景 陈老师喜欢网购书籍,经常一次购它个百八十本,然后拿来倒卖牟取暴利.(ps:描述要看懂) 题目描述 前些天,高一的新同学来了,他便像往常一样兜售他的书,经过一番口舌,同学们 ...

  2. 又一次认识java(一) ---- 万物皆对象

    假设你现实中没有对象.至少你在java世界里会有茫茫多的对象,听起来是不是非常激动呢? 对象,引用,类与现实世界 现实世界里有许很多多的生物,非生物,跑的跳的飞的,过去的如今的未来的,令人眼花缭乱.我 ...

  3. 1.namesapce用法

    namespace用法示例 #include <iostream> using namespace std; //定义域名空间 namespace myspace { ; void sho ...

  4. 深拷贝&浅拷贝

    1.区别 浅拷贝:只拷贝了基本数据类型,引用数据类型只复制了引用,没有复制实体. 深拷贝:拷贝所有的层级属性 2.浅拷贝 (1) 直接赋值 拷贝之后,所有层级属性仍然公用了地址,会被影响 var a ...

  5. 观察者模式 VS 责任链模式

    为什么要把观察者模式和责任链模式放在一起对比呢?这两个模式没有太多的相似性呀,真没有嘛?有相似性,我们在观察者模式中也提到了触发链(也叫做观察者链)的问题,一个具体的角色既可以是观察者,也可以是被观察 ...

  6. ZOJ 2723 Semi-Prime ||ZOJ 2060 Fibonacci Again 水水水!

    两题水题: 1.如果一个数能被分解为两个素数的乘积,则称为Semi-Prime,给你一个数,让你判断是不是Semi-Prime数. 2.定义F(0) = 7, F(1) = 11, F(n) = F( ...

  7. Centos 6 DNS Server 配置

    安装bind yum install -y bind bind-chroot bind-utis 如果是Centos 5 # yum -y install bind caching-nameserve ...

  8. windows SID

    显示SID whoami /user 修改SID C:\windows\system32\sysprep\sysprep.exe /generalize /oobe /reboot

  9. 11.2 Android显示系统框架_android源码禁用hwc和GPU

    2. 修改tiny4412_Android源码禁用hwc和gpu(厂家不会提供hwc和gpu的源代码,没有源代码就没法分析了,因此在这里禁用该功能并用软件库实现)最终源码: git clone htt ...

  10. zynq mac地址修改

    工作中遇到多个zynq板子同时位于一个交换机网络中,由于默认mac地址相同,无法进行通信,因此需要对每个板子修改mac地址. 方案:使用uboot配置文件 步骤: 在uboot配置文件中添加及修改下面 ...