• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
BearRui(AK-47)
花开有时,错过了一日便错过了一季,就象人生错过了相遇,就不再找寻到美丽的相聚
博客园    首页    新随笔    联系   管理    订阅  订阅
[翻译] IE7,IE8 BUG导致CSS下载二次。
为了压缩html代码,我们常常会去掉"删除HTTP或者HTTPS",即去掉url中的http(s)协议头,以节省空间,但这样使用后发现IE7,IE8会出现对同1个CSS加载2次的BUG。

      为了压缩html代码,我们常常会去掉"HTTP或者HTTPS",即去掉url中的http(s)协议头,以节省空间,但这样使用后发现IE7,IE8会出现对同1个CSS加载2次的BUG。

 

测试:
   正常的CSS加载代码写法:
  <link rel="stylesheet" href="http://www.test.com/main.css" type="text/css" />  
  这样写大家都知道加载是不会有任何问题的,所以也不贴监控图解释了
 
 在经过html压缩后,代码变成如下: 
  <link rel="stylesheet" href="//www.test.com/main.css" type="text/css" />
  压缩后,心里暗爽,html代码又小了,运行程序也没发现啥问题。
 
 在一次使用httpwatch监控的时候(IE8),竟然发现了严重的BUG,测试代码如下(加上了js和image为了方便测试):

测试:
     正常的CSS加载代码写法:  

     <link rel="stylesheet" href="http://www.test.com/main.css" type="text/css" />  

     这样写大家都知道加载是不会有任何问题的,所以也不贴监控图解释了。

 

    在经过html压缩后(去掉http协议头),代码变成如下:   

    <link rel="stylesheet" href="//www.test.com/main.css" type="text/css" />  

   压缩后,心里暗爽,html代码又小了, 可是用httpwatch监控一下IE8就发现问题了,测试代码如下(加上了js和image为了方便进行比较):

          <head>

		<title>http test</title>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
		<link rel="stylesheet" href="//www.test.com/css/main.css" type="text/css" /> 
		<script type="text/javascript" src="//www.test.com/css/1.js"></script> 
	</head>
	<body>
		<h1>test</h1>
		<img src="//www.test.com/css/d1.gif" />
	</body>	

   httpwatch监控图:

   

   oh shit,CSS竟然下载了二次,而且第二次还不是用的缓存,仍然响应200状态。

 

  再把连接css代码的href加上http协议头试试:

	<head>
		<title>http test</title>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
		<link rel="stylesheet" href="http://www.test.com/css/main.css" type="text/css" /> 
		<script type="text/javascript" src="//www.test.com/css/1.js"></script> 
	</head>
	<body>
		<h1>test</h1>
		<img src="//www.test.com/css/d1.gif" />
	</body>

  监控图:

  

  一切正常了。

 

总结:

     上面问题在IE8,IE7中都会出现,IE6、firefox、chrome都是正常的,而且只会对css有这个问题,js、image都正常,产生根本原因不详。

 

如果本机只有1个浏览器,不好进行测试,可以使用www.webpagetest.org在线进行测试,www.webpagetest.org同时支持IE7和IE8进行测试。

 

原文地址:http://www.stevesouders.com/blog/2010/02/10/5a-missing-schema-double-download/

 

PS: 虽然标题写的是翻译,但看了原文的就知道,其实根本不是翻译,是看了原文后本人根据原文进行了一翻测试,然后把测试结果写出来。

      因为本人英语水平比较差,所以没有直接翻译。

 

[作者]:BearRui(AK-47)
[博客]: http://www.cnblogs.com/BearsTaR/
[声明]:本博所有文章版权归作者所有(除特殊说明以外),转载请注明出处.
posted on 2010-05-28 09:05  BearRui(AK-47)  阅读(3755)  评论(28)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3