博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
uni 页面加载完毕_HTML页面生命周期
阅读量:6279 次
发布时间:2019-06-22

本文共 1136 字,大约阅读时间需要 3 分钟。

这是前端网络填坑的一篇,主要介绍三个事件DOMContentLoaded,load,beforeunload/unload以及相应的用法。

  • load— 浏览器已经加载了所有的资源(图像,样式表等)。可以在此事件触发时获得图像的大小(如果没有被在HTML/CSS中指定)
  • DOMContentLoaded— 浏览器已经完全加载了HTML,DOM树已经构建完毕之后会运行该事件,但是像是<img>和样式表等外部资源可能并没有下载完毕。所以js可以访问所有DOM节点,初始化界面。
document.addEventListener('DOMContentLoaded', () => console.log('haahhaha'))
  • beforeunload/unload-- 当用户离开页面的时候触发 。可以询问用户是否保存了更改以及是否确定要离开页面。

DOMContentLoaded 与脚本

仅从定义上看DOMContentLoaded事件也是很简单,就是在dom树构建完毕触发,不过其实存在一些坑:

419c34a9a87420d762e4d3c7ce2429bf.png

1。当浏览器在解析HTML页面时遇到了<script>...</script>标签,将无法继续构建DOM树(译注:UI渲染线程与JS引擎是互斥的,当JS引擎执行时UI线程会被挂起),必须立即执行脚本。所以DOMContentLoaded有可能在所有脚本执行完毕后触发。外部脚本(带src的)的加载和解析也会暂停DOM树构建,所以DOMContentLoaded也会等待外部脚本(图的第一种情况)。

2。async的脚本的下载和HTML的下载与解析是异步的,但js的执行一定和UI线程是互斥的。async在下载完毕后的执行会阻塞HTML的解析(情况2)。注意这个图说的不是太清晰,async的执行一定在load之前,但会在DOMContentLoaded的之前和之后都有可能

054231bb2096aaf58b2fb8971f7447a0.png

3。带有defer的脚本的下载是和HTML的下载与解析是异步的,但是js的执行会在HTML解析之后执行,执行完defer之后才会走到 DOMContentLoad

47d41d876a55431befa765e317ccf09b.png

window.onload

window对象上的onload事件在所有文件包括样式表,图片和其他资源下载完毕后触发

window.onbeforeunload

window.onbeforeunload = function () {    alert("There are unsaved changes. Leave now?")};

window.unonload

用户离开页面的时候,window对象上的unload事件会被触发,我们可以做一些不存在延迟的事情,比如关闭弹出的窗口,可是我们无法阻止用户转移到另一个页面上

转载地址:http://grjva.baihongyu.com/

你可能感兴趣的文章
企业中最佳虚拟机软件应用程序—Parallels Deskto
查看>>
Nginx配置文件详细说明
查看>>
怎么用Navicat Premium图标编辑器创建表
查看>>
Spring配置文件(2)配置方式
查看>>
MariaDB/Mysql 批量插入 批量更新
查看>>
ItelliJ IDEA开发工具使用—创建一个web项目
查看>>
solr-4.10.4部署到tomcat6
查看>>
切片键(Shard Keys)
查看>>
淘宝API-类目
查看>>
virtualbox 笔记
查看>>
Git 常用命令
查看>>
驰骋工作流引擎三种项目集成开发模式
查看>>
SUSE11修改主机名方法
查看>>
jdk6.0 + Tomcat6.0的简单jsp,Servlet,javabean的调试
查看>>
Android:apk签名
查看>>
2(2).选择排序_冒泡(双向循环链表)
查看>>
MySQL 索引 BST树、B树、B+树、B*树
查看>>
微信支付
查看>>
CodeBlocks中的OpenGL
查看>>
短址(short URL)
查看>>