免费邮箱 |加入收藏 | 会员中心 | 我要投稿 | RSS
您当前的位置:首页 > 网页制作 > CSS基础

IE和Firefox浏览器CSS兼容性技巧整理

时间:2011-05-19 08:29:51  来源:  作者:潘春会
http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  <style type="text/css">
  <!--
  div {
  cursor:pointer;
  width:200px;
  height:200px;
  border:10px solid red
  }
  -->
  </style>
  <div ōnclick="alert(this.offsetWidth)">让FireFox与IE兼容</div>

  IE7.0对CSS的支持又有新问题,解决如下。

  第一种,CSS HACK

  Bpx; /*For IE7 & IE6*/
  _height:20px; /*For IE6*/

  注意顺序。

  下面这样也属于CSS HACK,不过没有上面这样简洁。

  #example { color: #333; } /* Moz */
  * html #example { color: #666; } /* IE6 */
  *+html #example { color: #999; } /* IE7 */

  第二种,是使用IE专用的条件注释

  <!--其他浏览器 -->
  <link rel="stylesheet" type="text/css" href="css.css" />

  <!--[if IE 7]>
  <!-- 适合于IE7 -->
  <link rel="stylesheet" type="text/css" href="ie7.css" />
  <![endif]-->

  <!--[if lte IE 6]>
  <!-- 适合于IE6及一下 -->
  <link rel="stylesheet" type="text/css" href="ie.css" />
  <![endif]-->

  第三种,css filter的办法,以下是从国外网站翻译过来的。

  新建一个css样式如下:

  #item {
  width: 200px;
  height: 200px;
  background: red;
  }

  新建一个div,并使用前面定义的css的样式:

  <div id="item">some text here</div>

  在body表现这里加入lang属性,中文为zh:

  <body lang="en">

  现在对div元素再定义一个样式:

  *:lang(en) #item{
  background:green !important;
  }

  这样做是为了用!important覆盖原来的css样式,由于:lang选择器ie7.0并不支持,所以对这句话不会有任何作用,于是也达到了 ie6.0下同样的效果,但是很不幸地的是,safari同样不支持此属性,所以需要加入以下css样式:

  #item:empty {
  background: green !important
  }

  :empty选择器为css3的规范,尽管safari并不支持此规范,但是还是会选择此元素,不管是否此元素存在,现在绿色会现在在除ie各版本以外的浏览器上。

  对IE6和FF的兼容可以考虑以前的!important 个人比较喜欢用第一种,简洁,兼容性比较好。

来顶一下
返回首页
返回首页
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表
推荐资讯
如何找出DHCP地址池里未使用的IP地址
如何找出DHCP地址池里
国内常用的DNS列表
国内常用的DNS列表
Linux邮件服务器软件比较
Linux邮件服务器软件比
学用纯CSS打造可折叠树状菜单
学用纯CSS打造可折叠树
相关文章
    无相关信息
栏目更新
栏目热门