admin管理员组

文章数量:1559105

除ie外都可识别



 
 
 
 







如:
 
 
 
 
 
 

 

ie10/11不支持条件性注释后的

 

替代方法

 

专门针对ie的条件性注释(conditional comments)是个很奇葩的东西,它是专门给ie浏览器准备的,因为其它浏览器根本不能识别这种标记。之所以需要这种东西,是因为ie实现的网页渲染效果和其它浏览器又很多出入,使用条件性注释可以区别对待的针对浏览器编写css等代码。

[html]  view plain  copy  
  1. <span class="token comment">span>  
  2. <span class="token style language-css"><span class="token tag" style="color:rgb(153,0,85);"><span class="token tag"><span class="token punctuation" style="color:rgb(153,153,153);"><span>stylespan> <span class="token attr-name" style="color:rgb(102,153,0);">typespan><span class="token attr-value" style="color:rgb(0,119,170);"><span class="token punctuation" style="color:rgb(153,153,153);">=span><span class="token punctuation" style="color:rgb(153,153,153);">"span>text/css<span class="token punctuation" style="color:rgb(153,153,153);">"span>span><span class="token punctuation" style="color:rgb(153,153,153);">>span>span>  
  3. <span class="token comment">/* styles goes here but should not appear in ie5-9 */span>  
  4. <span class="token tag" style="color:rgb(153,0,85);"><span class="token tag"><span class="token punctuation" style="color:rgb(153,153,153);">span>stylespan><span class="token punctuation" style="color:rgb(153,153,153);">>span>span>span>  
  5. <span class="token comment">span>  

但当ie的版本到到达10/11后,开始不支持这种条件性注释(msdn上的说明)。

说来也合情合理,从ie9开始,ie开始被web开发人员接受,很多人将ie9后的浏览器和火狐、谷歌浏览器统称为现代浏览器,因为它们开始实现新的html5和css3统一标准。但愿望是美好的,现实却是残酷的,很多web开发人员在开发实践中发现,同一个css在ie9/10/11上显示的效果和其它浏览器渲染的效果还是不一样。也就是说,我们还是需要条件性注释。

那么,在不支持条件性注释的ie10/11上,如何实现条件性注释的效果呢?

方法一:使用ie=emulateie9属性指示浏览器采用ie9渲染技术

ie9是支持条件性注释的。

[html]  view plain  copy  
  1. <span class="token tag" style="color:rgb(153,0,85);"><span class="token tag"><span class="token punctuation" style="color:rgb(153,153,153);"><span>metaspan> <span class="token attr-name" style="color:rgb(102,153,0);">http-equivspan><span class="token attr-value" style="color:rgb(0,119,170);"><span class="token punctuation" style="color:rgb(153,153,153);">=span><span class="token punctuation" style="color:rgb(153,153,153);">"span>x-ua-compatible<span class="token punctuation" style="color:rgb(153,153,153);">"span>span> <span class="token attr-name" style="color:rgb(102,153,0);">contentspan><span class="token attr-value" style="color:rgb(0,119,170);"><span class="token punctuation" style="color:rgb(153,153,153);">=span><span class="token punctuation" style="color:rgb(153,153,153);">"span>ie<span class="token punctuation" style="color:rgb(153,153,153);">=span>emulateie9<span class="token punctuation" style="color:rgb(153,153,153);">"span>span><span class="token punctuation" style="color:rgb(153,153,153);">>span>span>  

在html网页的head里加入上面的元标记,这样ie10/11就能识别条件性注释了,我们也就可以像ie6/7/8那样编写针对性的css代码了。但这样做有个弊端,很显然,浏览器这样就会才能ie9的渲染模式,而不是最新的ie10/11技术。

方法二:使用媒体查询语句 -ms-high-contrast属性

css的媒体查询语句(media query)是一种高级的css条件语句,它能根据一些属性和属性值计算判断css是否可以生效。在这里,我们要使用一个ie10/11独有的属性,它就是-ms-high-contrast,只有ie10/11实现了这个属性,它可以有两个值activenone,使用下面的媒体查询语句:

[css]  view plain  copy  
  1. "token atrule" style="color:rgb(0,119,170);">"token rule">@media all and "token punctuation" style="color:rgb(153,153,153);">("token property" style="color:rgb(153,0,85);">-ms-high-contrast"token punctuation" style="color:rgb(153,153,153);">: none"token punctuation" style="color:rgb(153,153,153);">)"token punctuation" style="color:rgb(153,153,153);">("token property" style="color:rgb(153,0,85);">-ms-high-contrast"token punctuation" style="color:rgb(153,153,153);">: active"token punctuation" style="color:rgb(153,153,153);">) "token punctuation" style="color:rgb(153,153,153);">{  
  2. "token comment">/* ie10  css styles go here */  
  3. "token punctuation" style="color:rgb(153,153,153);">}  

火狐浏览器、谷歌浏览器不能识别这个属性,所以不会执行这个查询语句里的css,从而实现了条件性执行的效果。

方法三:使用javascript判断浏览器的类型

先用javascript判断是否是ie浏览器,如果是,就在页面的标记上添加一个“ie”的类名:

[js]  view plain  copy  
  1. class="token keyword" style="color:rgb(0,119,170);">var ms_ie class="token operator" style="color:rgb(166,127,89);">= class="token keyword" style="color:rgb(0,119,170);">falseclass="token punctuation" style="color:rgb(153,153,153);">;  
  2. class="token keyword" style="color:rgb(0,119,170);">var ua class="token operator" style="color:rgb(166,127,89);">= windowclass="token punctuation" style="color:rgb(153,153,153);">.navigatorclass="token punctuation" style="color:rgb(153,153,153);">.useragentclass="token punctuation" style="color:rgb(153,153,153);">;  
  3. class="token keyword" style="color:rgb(0,119,170);">var old_ie class="token operator" style="color:rgb(166,127,89);">= uaclass="token punctuation" style="color:rgb(153,153,153);">.class="token function" style="color:rgb(221,74,104);">indexofclass="token punctuation" style="color:rgb(153,153,153);">(class="token string" style="color:rgb(102,153,0);">'msie 'class="token punctuation" style="color:rgb(153,153,153);">)class="token punctuation" style="color:rgb(153,153,153);">;  
  4. class="token keyword" style="color:rgb(0,119,170);">var new_ie class="token operator" style="color:rgb(166,127,89);">= uaclass="token punctuation" style="color:rgb(153,153,153);">.class="token function" style="color:rgb(221,74,104);">indexofclass="token punctuation" style="color:rgb(153,153,153);">(class="token string" style="color:rgb(102,153,0);">'trident/'class="token punctuation" style="color:rgb(153,153,153);">)class="token punctuation" style="color:rgb(153,153,153);">;  
  5.       
  6. class="token keyword" style="color:rgb(0,119,170);">if class="token punctuation" style="color:rgb(153,153,153);">(class="token punctuation" style="color:rgb(153,153,153);">(old_ie class="token operator" style="color:rgb(166,127,89);">> class="token operator" style="color:rgb(166,127,89);">-class="token number" style="color:rgb(153,0,85);">1class="token punctuation" style="color:rgb(153,153,153);">) class="token operator" style="color:rgb(166,127,89);">|| class="token punctuation" style="color:rgb(153,153,153);">(new_ie class="token operator" style="color:rgb(166,127,89);">> class="token operator" style="color:rgb(166,127,89);">-class="token number" style="color:rgb(153,0,85);">1class="token punctuation" style="color:rgb(153,153,153);">)class="token punctuation" style="color:rgb(153,153,153);">) class="token punctuation" style="color:rgb(153,153,153);">{  
  7.     ms_ie class="token operator" style="color:rgb(166,127,89);">= class="token keyword" style="color:rgb(0,119,170);">trueclass="token punctuation" style="color:rgb(153,153,153);">;  
  8. class="token punctuation" style="color:rgb(153,153,153);">}  
  9.       
  10. class="token keyword" style="color:rgb(0,119,170);">if class="token punctuation" style="color:rgb(153,153,153);">( ms_ie class="token punctuation" style="color:rgb(153,153,153);">) class="token punctuation" style="color:rgb(153,153,153);">{  
  11.    documentclass="token punctuation" style="color:rgb(153,153,153);">.documentelementclass="token punctuation" style="color:rgb(153,153,153);">.classname class="token operator" style="color:rgb(166,127,89);"> class="token operator" style="color:rgb(166,127,89);">= class="token string" style="color:rgb(102,153,0);">" ie"class="token punctuation" style="color:rgb(153,153,153);">;  
  12. class="token punctuation" style="color:rgb(153,153,153);">}  

有了这个标志性css class后,我们就可以在css里区别性的编写css代码了。

[css]  view plain  copy  
  1. "token selector" style="color:rgb(102,153,0);">.testclass"token punctuation" style="color:rgb(153,153,153);">{  
  2.     "token comment">/*这里写通用的css*/   
  3. "token punctuation" style="color:rgb(153,153,153);">}  
  4.   
  5. "token selector" style="color:rgb(102,153,0);">.ie .testclass"token punctuation" style="color:rgb(153,153,153);">{  
  6.     "token comment">/*这里写专门针对ie的css*/  
  7. "token punctuation" style="color:rgb(153,153,153);">}  

这三种方法都能实现在ie10/11里条件性注释的替代效果,各有各的使用场景,我们根据软件的运行环境来选择使用哪一种。

 

 

延伸阅读: 

“浏览器内核”主要指渲染引擎(rendering engine),负责解析网页语法(如html、javascript)并渲染、展示网页。因此,所谓的浏览器内核通常也就是指浏览器所采用的渲染引擎,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。不同的浏览器内核对网页编写语法的解析也有所不同,因此同一网页在不同的内核浏览器里的渲染、展示效果也可能不同。

  浏览器内核种类繁多,商用的加上非商业的免费内核,大约会超过10款,我们今天重点看一下目前主流的四大浏览器内核trident、gecko、webkit以及presto。

  一、trident内核(代表:internet explorer)

  说起trident,很多人都会感到陌生,但提起ie(internet explorer)则无人不知无人不晓,由于其被包含在全世界使用率最高的操作系统windows中,得到了极高的市场占有率,所以我们又经常称其为ie内核。

  trident(又称为mshtml),是微软开发的一种排版引擎。它在1997年10月与ie4一起诞生,一直在被不断地更新和完善。而且除ie外,许多产品都在使用trident核心,比如windows的help程序、realplayer、windows media player、windows live messenger、outlook express等等都使用了trident技术。

  trident实际上是一款开放的内核,trident引擎被设计成一个软件模块,使得其他软件开发人员很容易将网页浏览功能加到他们自行开发的应用程序里,其接口内核设计相当成熟,因此涌现出许多采用ie内核而非ie的浏览器,但是trident只能用于windows平台。使用trident渲染引擎的浏览器包括:ie、傲游、世界之窗浏览器、avant、腾讯tt、sleipnir、gosurf、greenbrowser和kkman等。

  二、gecko内核(代表:mozilla firefox)

  gecko是开放源代码、以c 编写的网页排版引擎,目前被mozilla家族网页浏览器以及netscape 6以后版本浏览器所使用。这款软件原本是由网景通讯公司开发的,现在则由mozilla基金会维护。由于gecko的特点是代码完全公开,因此,其可开发程度很高,全世界的程序员都可以为其编写代码,增加功能。因为这是个开源内核,因此受到许多人的青睐,采用gecko内核的浏览器也很多,这也是gecko内核虽然年轻但市场占有率能够迅速提高的重要原因。

  gecko排版引擎提供了一个丰富的程序界面以供与互联网相关的应用程序使用,例如网页浏览器、html编辑器、客户端/服务器等。虽然最初的主要对象是mozilla的衍生产品,如netscape和mozilla firefox,但是现在已有很多其他软件利用这个排版引擎。此外gecko也是一个跨平台内核,可以在windows、bsd、linux和mac os x中使用。

  正在和曾经使用gecko引擎的浏览器有firefox、网景6~9、seamonkey、camino、mozilla、flock、galeon、k-meleon、minimo、sleipni、songbird、xerobank。google gadget引擎采用的就是gecko浏览器引擎。

  三、webkit内核(代表:safari、chrome)

  webkit 是一个开放源代码的浏览器引擎(web browser engine),webkit最初的代码来自kde的khtml和kjs(它们均为开放源代码,都是自由软件,在gpl协议下授权)。所以webkit也是自由软件,同时开放源代码。它的特点在于源码结构清晰、渲染速度极快。主要代表产品有safari和google的浏览器chrome。

  webkit内核在手机上的应用也十分广泛,例如google的android平台浏览器、apple的iphone浏览器、nokia s60浏览器等所使用的浏览器内核引擎,都是基于webkit引擎的。 webkit内核也广泛应用于widget引擎产品,包括中国移动的bae、apple的dashboard以及nokia wrt在内采用的均为webkit引擎。

  四、presto内核(代表:opera)

  presto是由opera software开发的浏览器排版引擎,供opera 7.0及以上使用。它取代了旧版opera 4至6版本使用的elektra排版引擎,包括加入动态功能,例如网页或其部分可随着dom及script语法的事件而重新排版。presto的特点就是渲染速度的优化达到了极致,它是目前公认的网页浏览速度最快的浏览器内核,然而代价是牺牲了网页的兼容性。

  presto实际上是一个动态内核,与trident、gecko等内核的最大区别就在于脚本处理上,presto有着天生的优势,页面的全部或者部分都能够在回应脚本事件时等情况下被重新解析。此外该内核在执行javascript时有着最快的速度,根据同等条件下的测试,presto内核执行同等javascript所需的时间仅有trident和gecko内核的约1/3。presto是商业引擎,了opera以外较少浏览器使用presto内核,这在一定程度上限制了presto的发展。

作者:天极软件责任编辑:杨玲) 转载:https://blog.csdn/a460550542/article/details/73521850

本文标签: 版本