在这次的产品发布中,客户发现了一个问题,就是在Firefox浏览器中,页面在加载的时候,出现没有样式的内容一闪而过的现象。其实,在测试过程中,我们也看到了类似的问题,但是并没有意识到这是一个问题,以为是网络慢导致的。

经过问题定位,发现这就是Flash of Unstyled Content (FOUC),也就是文档样式短暂失效。

从网络中查到了对应的解决方法:http://blog.sina.com.cn/s/blog_49e464d80100fm9h.html

什么是FOUC(文档样式短暂失效)?
如果使用import方法对CSS进行导入,会导致某些页面在Windows 下的Internet Explorer出现一些奇怪的现象:以无样式显示页面内容的瞬间闪烁,这似乎不可想象,我将这种现象称之为文档样式短暂失效(Flash of Unstyled Content),简称为FOUC.
因为这种奇怪的现象似乎只会在Internet Explorer中出现,我们尝试得出一个结论,很显然这是IE的一个问题.我不打算继续探讨这个结论.对我来说,我也不清楚是否FOUC只会给那些非W3C推荐的客户端带来困扰.尽管我不能代表W3C说些什么,但是我期待Internet Explorer能够对文档样式短暂实效进行深层次的发掘和研究.

我如何能看到FOUC
首先,你需要使用Windows版本的IE(版本5或更高级的版本),其次,你需要找到一个能够展示FOUC现象的页面,你不需要再去搜索了,这个页面就是个好例子.
在这里,提示很重要的一点.如果导入的样式表存在于IE的缓存(也称为IE临时文件)中,页面内容的瞬间无样式闪现将不会出现.出于测试目的,在测试FOUC页面之前需要删除IE临时文件,如果你不确认如何进行的话,你可以查看微软提供的相关在线帮助.下面我给出测试FOUC的建议步骤:
1 使用IE5+/Win载入测试的FOUC页面,这个页面就是绝好的例子;
2 载入一个不同的页面,在这个步骤中,你选择哪个页面并不是重要的,只要它不和你所测试的页面共享文件,最好选择一个不同网站的页面;
3 删除IE临时文件;
4 点击后退按钮返回你要测试的页面
5 查看文档样式短暂失效现象

注意一些因素,例如运行迟缓的电脑和网络设备缓存能力,可能会降低显示内容瞬间无样式闪烁的几率.

如何解决FOUC
只需要在文档的head元素中添加一个link元素或者添加script元素就可以防止FOUC的发生.

基础head 元素
出于比较目的,下面的是出现FOUC的基本head元素内容
测试此基础head元素显示FOUC现象

  1. <head>
  2. <title>My Page</title>
  3. <style type=”text/css” media=”screen”>@import “style.css”;</style>
  4. </head>

link元素解决方案
在基础的head元素中添加link元素可能是最合适的解决方案,这是因为添加一个alternate样式表 或 media-dependent 样式表对每个页面来说都会有好处.我推荐这种方法,由于这样既可以阻止FOUC现象的发生,同时也可以给页面带来一些提升,例如可用性,可访问性或者其他热门词.当然,如果你添加的link元素所添加的是一个空样式表的话也是可以的,但是这将是多大的浪费.

测试link元素解决方案处理后的FOUC页面

  1. <head>
  2. <title>My Page</title>
  3. <link rel=”stylesheet” type=”text/css” media=”print” href=”print.css” mce_href=”print.css”>
  4. <style type=”text/css” media=”screen”>@import “style.css”;</style>
  5. </head>

script元素解决方案
添加script元素也是一种有效的解决方案,尽管如此,这种方法在某些情况下看起来是那么不自然,例如,我觉得没有任何脚本可以提升页面.我可以添加空白的script元素到head元素中,但是这样似乎感觉和hack一样糟糕.这种情况下,可以选择link元素解决方案.
我提及一下,script元素不一定非要添加到head元素中,但是需要在body元素内容之前填写这个标签,因此可以将script元素防止在body中,但是一定要置于可视内容之前,也是有效的.
测试script元素解决方案处理后的FOUC页面

    1. <head>
    2. <title>My Page</title>
    3. <script type=”text/javascript”> </script>
    4. <style type=”text/css” media=”screen”>@import “style.css”;</style>
    5. </head>

最新文章

  1. 在开启DRS的集群中修复VMware虚拟主机启动问题
  2. MySQL实现两张表数据的同步
  3. java url encoder 的一个问题
  4. Welcome to China
  5. 禁止用户选定文本: user-select
  6. 预处理prepareStatement是怎么防止sql注入漏洞的?
  7. Jquery+Ajax+php学习笔记
  8. Ext中图片上传预览的问题,困扰了好几天终于解决了,记录下
  9. Javascript模块化编程之难处
  10. opencv----人脸美白算法,祛斑,祛痘,磨皮等
  11. (64)Wangdao.com第十天_JavaScript 对象的 toString() 方法改变输出
  12. POJ - 3264——Balanced Lineup(入门线段树)
  13. 关于@Param
  14. Leetcode 1014. 在 D 天内送达包裹的能力
  15. H5离线缓存技术Application Cache
  16. 翻译api调用
  17. axis2的WebService无法注入Service层类
  18. maven Could not find artifact com.** 无法下载原因分析
  19. ajax跨域请求在IE8中存在的问题
  20. 【HLSDK系列】overview(俯视图)

热门文章

  1. SQLSERVER XML 类型列的模糊查询
  2. 实现多层抽屉菜单,点击其中一项会动画打开该抽屉--第三方开源--MultiCardMenu
  3. Python&amp;&amp;ipython安装注意事项
  4. 树莓派(Arduino)仿真软件 —— Fritzing
  5. 3.4 常用的两种 layer 层 3.7 字体与文本
  6. AJAX的最小单元
  7. [独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数
  8. JSDoc 介绍
  9. VS中添加自定义代码片段
  10. js 科学计数转数字或字符串