详解关于html,css,js三者的加载顺序问题


Posted in Javascript onApril 10, 2019
<head lang="en">
  <meta charset="utf-8">
  <title></title>
  <link rel="stylesheet" href="css/*.css" rel="external nofollow" >
  <script src="js/*.js></script>
</head>

DOM文档的加载顺序是由上而下的顺序加载;

1、DOM加载到link标签

css文件的加载是与DOM的加载并行的,也就是说,css在加载时Dom还在继续加载构建,而过程中遇到的css样式或者img,则会向服务器发送一个请求,待资源返回后,将其添加到dom中的相对应位置中;

2、DOM加载到script标签

由于js文件不会与DOM并行加载,因此需要等待js整个文件加载完之后才能继续DOM的加载,倘若js脚本文件过大,则可能导致浏览器页面显示滞后,出现“假死”状态,这种效应称之为“阻塞效应”;会导致出现非常不好的用户体验;

而这个特性也是为什么在js文件中开头需要$(document).ready(function(){})或者(function(){})或者window.onload,即是让DOM文档加载完成之后才执行js文件,这样才不会出现查找不到DOM节点等问题;

js阻塞其他资源的加载的原因是:浏览器为了防止js修改DOM树,需要重新构建DOM树的情况出现;

3、解决方法

前提,js是外部脚本;

在script标签中添加 defer=“ture”,则会让js与DOM并行加载,待页面加载完成后再执行js文件,这样则不存在阻塞;

在scirpt标签中添加 async=“ture”,这个属性告诉浏览器该js文件是异步加载执行的,也就是不依赖于其他js和css,也就是说无法保证js文件的加载顺序,但是同样有与DOM并行加载的效果;

同时使用defer和async属性时,defer属性会失效;

可以将scirpt标签放在body标签之后,这样就不会出现加载的冲突了。

以上所述是小编给大家介绍的关于html,css,js三者的加载顺序问题详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery的一些注意
Dec 06 Javascript
把textarea中字符串里含有的回车换行替换成&amp;lt;br&amp;gt;的javascript代码
Apr 20 Javascript
JS 判断代码全收集
Apr 28 Javascript
js文件中调用js的实现方法小结
Oct 23 Javascript
JavaScript Sort 表格排序
Oct 31 Javascript
js实现在字符串中提取数字
Nov 05 Javascript
JS修改iframe页面背景颜色的方法
Apr 01 Javascript
jQuery实现立体式数字动态增加(animate方法)
Dec 21 Javascript
用vue快速开发app的脚手架工具
Jun 11 Javascript
React之PureComponent的使用作用
Jul 10 Javascript
javascript实现函数柯里化与反柯里化过程解析
Oct 08 Javascript
vue-cli3中配置alias和打包加hash值操作
Sep 04 Javascript
angular2 NgModel模块的具体使用方法
Apr 10 #Javascript
bootstrap tooltips在 angularJS中的使用方法
Apr 10 #Javascript
javascript判断一个变量是数组还是对象
Apr 10 #Javascript
Angular CLI 使用教程指南参考小结
Apr 10 #Javascript
基于vue开发微信小程序mpvue-docs跳转页面功能
Apr 10 #Javascript
element-ui多文件上传的实现示例
Apr 10 #Javascript
基于mpvue搭建微信小程序项目框架的教程详解
Apr 10 #Javascript
You might like
[原创]PHP实现逐行删除文件右侧空格的方法
2015/12/25 PHP
Zend Framework教程之路由功能Zend_Controller_Router详解
2016/03/07 PHP
thinkPHP5分页功能实现方法分析
2017/10/25 PHP
laravel-admin 实现给grid的列添加行数序号的方法
2019/10/08 PHP
JavaScript基础知识之数据类型
2012/08/06 Javascript
JavaScript中使用Math.floor()方法对数字取整
2015/06/15 Javascript
JS表单提交验证、input(type=number) 去三角 刷新验证码
2017/06/21 Javascript
React学习笔记之列表渲染示例详解
2017/08/22 Javascript
vue-cli2.x项目优化之引入本地静态库文件的方法
2018/06/19 Javascript
vue服务端渲染添加缓存的方法
2018/09/18 Javascript
移动端 Vue+Vant 的Uploader 实现上传、压缩、旋转图片功能
2019/06/10 Javascript
关于layui的下拉搜索框异步加载数据的解决方法
2019/09/28 Javascript
微信小程序纯文本实现@功能
2020/04/08 Javascript
js实现tab栏切换效果
2020/08/02 Javascript
vue中可编辑树状表格的实现代码
2020/10/31 Javascript
[02:28]DOTA2英雄基础教程 灰烬之灵
2013/12/19 DOTA
[50:21]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第二场
2018/08/19 DOTA
跟老齐学Python之使用Python查询更新数据库
2014/11/25 Python
python中找出numpy array数组的最值及其索引方法
2018/04/17 Python
Python下调用Linux的Shell命令的方法
2018/06/12 Python
python3+PyQt5 创建多线程网络应用-TCP客户端和TCP服务器实例
2019/06/17 Python
tensorflow2.0的函数签名与图结构(推荐)
2020/04/28 Python
CSS3 制作旋转的大风车(充满童年回忆)
2013/01/30 HTML / CSS
Marc Jacobs彩妆官网:Marc Jacobs Beauty
2017/07/03 全球购物
保加利亚手表、香水、化妆品和珠宝购物网站:Brasty.bg
2020/04/22 全球购物
英文版餐饮业求职信
2013/10/18 职场文书
视光学专业毕业生推荐信
2013/10/28 职场文书
大学系主任推荐信范文
2013/12/24 职场文书
医院工作检讨书范文
2014/02/10 职场文书
优秀党员获奖感言
2014/02/18 职场文书
工作作风整顿个人剖析材料
2014/10/11 职场文书
领导干部个人整改措施落实情况汇报
2014/10/29 职场文书
追悼会答谢词
2015/01/05 职场文书
ThinkPHP5和ThinkPHP6的区别
2021/03/31 PHP
HTML5简单实现添加背景音乐的几种方法
2021/05/12 HTML / CSS
Python实现仓库管理系统
2022/05/30 Python