如何用CSS分别单独定义IE6、7、8的width属性

 我来答
纯洁的小树
2015-10-17 · TA获得超过3386个赞
知道大有可为答主
回答量:2536
采纳率:71%
帮助的人:473万
展开全部

使用CSS hack进行设置。CSS hack的目的就是使你的CSS代码兼容不同的浏览器。当然,我们也可以反过来利用CSS hack为不同版本的浏览器定制编写不同的CSS效果。


1.原理


  由于不同的浏览器对CSS的支持及解析结果不一样,还由于CSS中的优先级的关系。我们就可以根据这个来针对不同的浏览器来写不同的CSS。

 
 CSS Hack大致有3种表现形式,CSS类内部Hack、选择器Hack以及HTML头部引用(if IE)Hack,CSS
Hack主要针对类内部Hack:比如 IE6能识别下划线"_"和星号" * ",IE7能识别星号" *
",但不能识别下划线"_",而firefox两个都不能认识。等等

  选择器Hack:比如 IE6能识别*html .class{},IE7能识别*+html .class{}或者*:first-child+html .class{}。等等

 
 HTML头部引用(if IE)Hack:针对所有IE:<!--[if
IE]><!--您的代码--><![endif]-->,针对IE6及以下版本:<!--[if lt IE
7]><!--您的代码--><![endif]-->,这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都
会生效。

  书写顺序,一般是将识别能力强的浏览器的CSS写在后面。下面如何写里面说得更详细些。

2、常用的CSS hack方式

  

  (1)方式一 条件注释法

  只在IE下生效

  <!--[if IE]>

  这段文字只在IE浏览器显示

  <![endif]-->

  只在IE6下生效

  <!--[if IE 6]>

  这段文字只在IE6浏览器显示

  <![endif]-->

  只在IE6以上版本生效

  <!--[if gte IE 6]>

  这段文字只在IE6以上(包括)版本IE浏览器显示

  <![endif]-->

  只在IE8上不生效

  <!--[if ! IE 8]>

  这段文字在非IE8浏览器显示

  <![endif]-->

  非IE浏览器生效

  <!--[if !IE]>

  这段文字只在非IE浏览器显示

  <![endif]-->

  (2)方式二 类内属性前缀法

  属性前缀法是在CSS样式属性名前加上一些只有特定浏览器才能识别的hack前缀,以达到预期的页面展现效果。

  IE浏览器各版本 CSS hack 对照表

说明:在标准模式中

“-″减号是IE6专有的hack

“\9″ IE6/IE7/IE8/IE9/IE10都生效

“\0″ IE8/IE9/IE10都生效,是IE8/9/10的hack

“\9\0″ 只对IE9/IE10生效,是IE9/10的hack

(3)CSS hack方式三:选择器前缀法

选择器前缀法是针对一些页面表现不一致或者需要特殊对待的浏览器,在CSS选择器前加上一些只有某些特定浏览器才能识别的前缀进行hack。

目前最常见的是

*html *前缀只对IE6生效*+html *+前缀只对IE7生效@media
screen\9{...}只对IE6/7生效@media \0screen {body { background: red;
}}只对IE8有效@media \0screen\,screen\9{body { background: blue;
}}只对IE6/7/8有效@media screen\0 {body { background: green; }}
只对IE8/9/10有效@media screen and (min-width:0\0) {body { background: gray;
}} 只对IE9/10有效@media screen and (-ms-high-contrast: active),
(-ms-high-contrast: none) {body { background: orange; }} 只对IE10有效等等


3、实际应用

比如要分辨IE6和firefox两种浏览器,可以这样写:

div{
background:green;/*forfirefox*/
*background:red;/*forIE6*/(bothIE6&&IE7)
}

我在IE6中看到是红色的,在firefox中看到是绿色的。

  解释一下:

  上面的css在firefox中,它是认识不了后面的那个带星号的东西是什么的,于是将它过滤掉,不予理睬,解析得到的结果是:div{background:green},于是理所当然这个div的背景是绿色的。

  在IE6中呢,它两个background都能识别出来,它解析得到的结果是:div{background:green;*background:red;},于是根据优先级别,处在后面的red的优先级高,于是当然这个div的背景颜色就是红色的了。

4、所以单独定义IE6、7、8的width属性代码如下

div{
width:200px;/*所有浏览器都能识别 包括IE7*/
-width:180px;/*只有IE6识别,识别后会覆盖通用width的设置,达到IE6单独设置的效果*/
-width:180px\0;/*IE8以上的浏览器识别,识别后会覆盖通用width的设置,达到IE8单独设置的效果*/
}
tangguyan
推荐于2018-04-12 · TA获得超过305个赞
知道答主
回答量:135
采纳率:100%
帮助的人:175万
展开全部
width:8px\0; /*ie8*/
+width:7px; /*ie7*/
_width:6px; /*ie6*/
你试试去
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
freezing866
2015-12-03 · 知道合伙人互联网行家
freezing866
知道合伙人互联网行家
采纳数:145 获赞数:1032
六年网站开发经验,开发过的网站超过百个。擅长B2B、B2C、营销型网站开发。公司网址:www.wangyingshi.com

向TA提问 私信TA
展开全部
你好,可以用hack来区分不同的IE浏览器:
仅IE6识别 : _margin-left:10px;
IE6/IE7识别 : *margin-left:10px;
仅IE8识别 : margin-left:10px\0;
仅IE识别 : margin-left:10px\9;
去试试吧,希望可以帮到你!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式