白屏问题与FOUC无样式内容闪烁/加载异步_html/css_WEB-ITnose
- 在探讨白屏问题和fouc无样式内容闪烁问题出现的原因之前,我们要知道的一个原则是浏览器在对于图片和css, 在加载时会并发加载(如一个域名下同时加载两个文件). 但在加载 javascript 时,会禁用并发,并且阻止其他内容的下载
为何出现白屏问题与fouc无样式内容闪烁?
- 在写html代码时,我们都是将css文件的引入位置放在头部(标签内部),将js文件的引入位置放在底部(前面)。
- 不同的浏览器对于css和html的处理方式不同,有的是等待css加载完成之后,对html元素进行渲染和展示(白屏问题)。有的是先对html元素进行展示,然后等待css加载完成之后重新对样式进行修改(fouc无样式内容闪烁)
- 如果把css样式放在底部,对于ie浏览器,在某些场景下(新窗口打开,刷新等)页面会出现白屏,而不是内容逐步展现,如果使用 @import标签,即使 css 放入 link, 并且放在头部,也可能出现白屏。
- 如果把css样式放在底部,对于ie浏览器,在某些场景下(点击链接,输入url,使用书签进入等),会出现 fouc 现象(逐步加载无样式的内容,等css加载后页面突然展现样式).对于 firefox 会一直表现出 fouc 。
- 如果把js文件放在头部,脚本会阻塞后面内容的呈现,脚本会阻塞其后组件的下载,出现白屏问题。
加载异步
- defer和asnyc是脚本异步加载的两种方式。
- defer,加载后续文档元素的过程将和 script.js 的加载并行进行(异步),但 script.js 的执行要在所有元素解析完成之后,domcontentloaded 事件触发之前完成。
- async,加载和渲染后续文档元素的过程将和 script.js 的加载与执行并行进行(异步)。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn