失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 页面加载时触发的事件及顺序

页面加载时触发的事件及顺序

时间:2020-05-12 09:28:44

相关推荐

页面加载时触发的事件及顺序

web前端|js教程

顺序,事件,触发

web前端-js教程

前言

android 高仿美团源码,vscode代码对齐,ubuntu 网速,怎样配置tomcat,arm sqlite,如何做一个简单的网页设计,mssql数据库申请,国外购买服务器,电脑插件后门,web 前端 框架,爬虫沙,curl php,seo页面优化,springboot高级功能,dede首页推荐标签,卢松松网站,网页变灰色怎么办,netcms模板,bootstrap后台管理系统模板,jquery 收藏当前页面,java电话簿管理系统,dz社区微信小程序lzw

页面加载时,大致可以分为以下几个步骤:

装修商城网站源码,vscode更新覆盖代码,ubuntu改变ld,tomcat 打开报错,c sqlite3库,爬虫爬取文本做词云,php上传文件 进度条,杏坛seo优化案例,租房网站模板,手机网页模板仿公众号,magento 2.0 模板lzw

开始解析HTML文档结构

查看源码工具,虚拟机上下载vscode,ubuntu看ppt,tomcat启动多线程,pythonGUI爬虫绘画,php 发帖机,万柏林区seo优化原则lzw

加载外部样式表及JavaScript脚本

解析执行JavaScript脚本

DOM树渲染完成

加载未完成的外部资源(如 图片)

页面加载成功

那么在这整个过程中触发了哪些常用的事件呢?

document readystatechange事件

readyState 属性描述了文档的加载状态,在整个加载过程中 document.readyState会不断变化,每次变化都会触发readystatechange事件。

readyState 有以下状态:

loading / 加载document仍在加载。

interactive / 互动文档已经完成加载,文档已被解析,但是诸如图像,样式表和框架之类的子资源仍在加载。

complete / 完成T文档和所有子资源已完成加载。状态表示load事件即将被触发。

比如说在步骤2的时候对应 interactive 步骤5之后对应complete ,都会触发readystatechange事件。

PS:文档,图片等加载时的readyState 和 XMLHttpRequest.readyState 是不一样的。要注意区分

document DOMContentLoaded事件

DOM树渲染完成时触发DOMContentLoaded事件,此时可能外部资源还在加载。 jquery中的ready事件就是同样的效果

window load事件

所有的资源全部加载完成会触发window 的 load事件。

doucment 的load事件无法触发,但是MDN上却有这个事件?求大神指导!!!

实例

测试页面加载时,事件触发次序

测试页面加载时,事件触发次序

测试页面加载时,事件触发次序

console.log( esolve body JavaScript); window.addEventListener(load,function(){console.log(window load); }) document.addEventListener( eadystatechange,function(){console.log(document + document.readyState); }) document.addEventListener(DOMContentLoaded,function(){console.log(document DOMContentLoaded); }) //document 没有load事件?? document.addEventListener(load,function(){console.log(document load); })

在chrome中的日志输出如下:

resolve body JavaScript –> document interactive –> document DOMContentLoaded –> document complete –> window load

完全符合预期有木有。所以在只需要文档结构加载完成就可以执行的脚本,可以监听DOMContentLoaded ;需要所有内容都加载完成才能执行的脚本,要监听window.onload 或者 document.readyState === ‘complete’。

如果觉得《页面加载时触发的事件及顺序》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。