各浏览器识别的代码

各浏览器识别的代码

<!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]-->

<!--[if IE]> 所有的IE可识别 <![endif]-->

<!--[if IE 6]> 仅IE6可识别 <![endif]-->

<!--[if lt IE 6]> IE6以及IE6以下版本可识别 <![endif]-->

<!--[if gte IE 6]> IE6以及IE6以上版本可识别 <![endif]-->

<!--[if IE 7]> 仅IE7可识别 <![endif]-->

<!--[if lt IE 7]> IE7以及IE7以下版本可识别 <![endif]-->

<!--[if gte IE 7]> IE7以及IE7以上版本可识别 <![endif]-->

<!--[if IE 8]> 仅IE8可识别 <![endif]-->

<!--[if IE 9]> 仅IE9可识别 <![endif]-->

  1. CSS中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义 !important 可被FireFox和IE7识别
  • 可被IE6、IE7识别 _ 可被IE6识别 *+ 可被IE7识别 区别IE6与FF: background:orange;*background:blue; 区别IE6与IE7: background:green !important;background:blue; 区别IE7与FF: background:orange; *background:green; 区别FF,IE7,IE6: background:orange;*background:green !important;*background:blue; IE7,IE8兼容:

<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />

  1. 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]-->

  1. 几个浏览器对实际像素的解释 IE/Opera:对象的实际宽度 = (margin-left) + width + (margin-right) Firefox/Mozilla:对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right)

  2. 鼠标手势问题:FireFox的cursor属性不支持hand,但是支持pointer,IE两个都支持;所以为了兼容都用pointer

  3. FireFox中设置HTML标签的Style属性时,所有位置、宽高和尺寸值必须后跟px,IE也支持此写法,因此统一加px单位。如 Obj.Style.Height = imgObj.Style.Height + ‘px';

  4. FireFox无法解析简写的padding属性设置,如padding 5px 4px 3px 1px;必须改为 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px0;

  5. 消除ul、ol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;其中margin属性对IE有效,padding属性对FireFox有效

  6. CSS控制透明:IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60); FireFox:opacity:0.6;

  7. CSS控制圆角:IE:不支持圆角;

FireFox: -moz-border-radius:4px;或 -moz-border-radius-topleft:4px; -moz-border-radius-topright:4px; -moz-border-radius-bottomleft:4px; -moz-border-radius- bottomright:4px;

  1. CSS双线凹凸边框:IE:border:2px outset;

FireFox: -moz-border-top-colors: #d4d0c8 white; -moz-border-left-colors: #d4d0c8 white; -moz-border-right-colors:#404040 #808080; -moz-border-bottom-colors:#404040 #808080;

  1. IE支持CSS方法cursor:url()自定义光标样式文件和滚动条颜色风格;FireFox对以上两者均不支持

  2. IE有Select控件永远处于最上层的bug,且所有CSS对Select控件都不起作用

  3. IE支持Form中的Label标签,包括图片和文字内容;FireFox不支持包含图片的Label,点击图片不能让标记 label for 的Radio或CheckBox产生效果

  4. FireFox中的TextArea不支持onScroll事件

  5. FireFox不支持display的inline和block

  6. FireFox对Div设置margin-left, margin-right为auto时已经居中, IE中不行

  7. FireFox对Body设置text-align时, Div需要设置margin: auto(主要是margin-left margin-right) 方可居中

  8. 对超链接的CSS样式设置最好遵从这样的顺序:L-V-H-A。即

<style type="text/css"> <!-- a:link {} a:visited {} a:hover {} a:active {} --> </style>

这样可以避免一些访问过后的超链接就不具备hover和active样式了

  1. IE中设置长段落自动换行在CSS中设置word-wrap:break-word;FireFox中使用JS插入 的方法来实现,具体代码如下:

<script type="text/javascript"> /* <![CDATA[ */ function toBreakWord(el, intLen){ var obj=document.getElementById(el); var strContent=obj.innerHTML; var strTemp=""; while(strContent.length>intLen){ strTemp+=strContent.substr(0,intLen)+" "; strContent=strContent.substr(intLen,strContent.length); } strTemp+=" "+strContent; obj.innerHTML=strTemp; } if(document.getElementById && !document.all) toBreakWord("div_id", 37); /* ]]> */ </script>

  1. 在子容器加了浮动属性后,该容器将不能自动撑开 解决方法:在标签结束后下一个标签中加上一个清除浮动的CSS clear:both;

  2. 浮动后IE6解释外边距为实际边距的双倍 解决办法:加上display:inline

  3. IE6下图片下方会有空隙 解决办法:为img加上display:block或设置vertical-align 属性为vertical-align:top | bottom |middle |text-bottom

  4. IE6下两个层中间有空隙 解决办法:设置右侧div也同样浮动float:left或者相对IE6定义 margin-right:-3px;

  5. LI中内容超过长度后以省略号的显示方法

<style type="text/css"> <!-- li { width:200px; white-space:nowrap; text-overflow:ellipsis; -o-text-overflow:ellipsis; overflow: hidden; } --> </style>

  1. 将元素的高度和行高设为相同值,即可垂直居中文本

<style type="text/css"> <!-- div { height:30px; line-height:30px; } --> </style>

  1. 对齐文本与文本输入框,须在CSS中增加vertical-align:middle;属性设置

<style type="text/css"> <!-- … … vertical-align:middle; } --> </style>

  1. 支持WEB标准的浏览器设置了固定高度值就不会像IE6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-height的IE6可以这样定义: { height:auto!important; height:200px; min-height:200px; }

  2. web标准中IE无法设置滚动条颜色 解决办法:在CSS中对body的设置改为对html的

<style type="text/css"> <!-- html { scrollbar-face-color:#f6f6f6; scrollbar-highlight-color:#fff; scrollbar-shadow-color:#eeeeee; scrollbar-3dlight-color:#eeeeee; scrollbar-arrow-color:#000; scrollbar-track-color:#fff; scrollbar-darkshadow-color:#fff; } --> </style>

  1. IE6由于默认行高问题无法定义1px左右高度的容器, 解决办法:在CSS中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px

  2. 给Flash设置透明属性可使层显示在Flash之上

<param name="wmode" value="transparent" /> <!-- 解决IE上的问题 //> <embed wmode="transparent" …… > <!-- 解决FireFox上的问题 //>

  1. FireFox设置Padding属性后会相应的增加Width和Height属性值,IE不会 解决办法:用!important方法多定义一套Height和Width

  2. FireFox对div与div之间的空格是忽略的,但IE是处理的;因此尽量在两个相连的div之间不要有空格和回车,否则可能会造成不同浏览器之间格式不正确,比如著名的3px偏差;而且原因很难查明

  3. 形如如下格式

<div id="parent"> <div id="content"> </div> </div> 当Content内容多时,即使parent设置了高度100%或auto,在不同浏览器下还是不能完好的自动伸展;解决办法在层的最下方产生一个高度为1的空格,代码如下 <div id="parent"> <div id="content"> </div> <div style="font: 0px/0px sans-serif;clear: both;display: block"> </div> </div>

  1. IE和FireFox对字体small的尺寸解释不同,FireFox为13px,IE中为16px

  2. IE和FireFox对空格的尺寸解释不同,FireFox为4px,IE中为8px

首先,关于CSS hack的方法网上有很多介绍,种类繁多,初学者常常感到很困惑。这类的CSS hack的方法,有的是针对某一个非常特殊的情况的方法,有的则是相对于比较通用的一些方法。 对于后者我们在平常的学习工作中,可以多留心收集一些,前者则不需要太关注,只是遇到的时候到网上搜索一下,寻找解决方法即可。 这里举一个比较通用的hack方法,比如对于CSS中的某一个属性,我们希望针对不同的浏览器,设置不同的值。例如,某一个div,我们希望在Firefox中宽度为50像素,在IE中宽度为60像素。那么怎么实现呢?请看如下代码:

#demo div{ width:50px; /* FireFox 有效 / +width:60px; / IE 有效 */ }

在上面的代码中, 第2行的width:50px这是普通的样式,下一行中,在width属性前面加一个加号,这条样式在Firefox中被认为无效,但是在IE中这个加号 会被忽略掉,因此仍然被理解为width属性,从而覆盖上一条的设置,这样就可以区分Firefox浏览器和IE浏览器了。 那么如果希望进一步区分IE 6和IE 7呢?请看如下代码:

#demo div{ width:50px; /* FireFox 有效 / +width:60px; / IE 7 有效 / _width:70px; / IE 6 有效 */ }

上面代码就可以实现对三种浏览器的区分了。在IE7中,属性前加一个加号,这个加号会被忽略,而如果在属性前加一个下划线这整条样式会被忽略,从而实现了对这三种主流浏览器的区分。 到这里,我们自然会想到,什么情况下会用的这种方法来区分浏览器呢?我们要制作的页面,通常会有两种情况,一种是彻底从头开始做,另一种是基于一个已经存在的网页进行修改或者修补。 对于第一种情况来说,我们对网页的每一个细节都十分清楚,因此并不经常遇到非常Firefox和IE的兼容性问题,即使遇到了,一般也可以找到其他 方法解决。而对于第二种情况来说,则复杂的多了,因为一个网页可能非常复杂,层叠关系也很复杂,对于后接手的人,很难搞清楚某一个的属性上面有多少层设置 会对他产生影响,因此往往只能采用“贴膏药”的方式进行修补。 比如说,如下的一个页面的最终效果,在制作圆角框的时候,在IE中,圆角对整齐之后,在firefox中却出现如图所示的错位,而如果按照Firefox调整好,在IE中又会出现错位。 而页面的内容层层嵌套,在并不知道细节的情况下,很难找到问题的根源。因此这里使用修补的方法就很方便(尽管不是最优雅完善的方法),例如对于控制圆角图像位置的属性使用上面的方法,分别控制即可。

综上所述,对任何属性都可以使用加号或者下划线方法,来实现针对不同浏览器的各自设置。当然,最后还是要指出,任何hack方法都要慎重使用,最好还是能够按照标准、优雅的CSS来进行设计,这样的代码可读性、维护性都要好很多,也是我们追求的目标。

为什么div+css在ie6没问题,在firfox有问题,严重走样,什么原因? IE和FF的比较大的区别是

1。在1024的分辨率下 IE最多显示1002PX FF显示1005PX

2。IE容错性超级强 也就是说 你代码写错了 少写了 也有可能显示正确 FF就不行~~~`一般新手常常出现的问题:没有清除浮动~~~~.clear{ clear:both; height:1px; top:-1px; overflow:hidden}在每一个浮动后面都加上一个<div class="clear"><div>

转载于:https://my.oschina.net/jiuban/blog/724585

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
webpack 是一个现代 JavaScript 应用程序的静态模块打包器。它可以分析应用程序的依赖关系,并根据这些依赖关系创建一个优化过的打包文件。 在浏览器端,Webpack 的代码分析主要有以下几个方面: 1. 代码依赖分析:Webpack 可以分析入口文件中的依赖关系,并递归地分析出所有相关的模块依赖关系。通过这种依赖分析,Webpack 可以准确地判断哪些模块需要被打包,以及它们之间的依赖关系。 2. 代码转换和优化:Webpack 支持各种加载器(loader)和插件(plugins),可以将各种类型的文件转换成浏览器识别的模块。例如,可以使用 Babel 加载器将 ES6/ES7 的语法转换成 ES5 的语法,或者使用 CSS 加载器将 CSS 文件转换成 JavaScript 对象。同时,Webpack 还可以对转换后的代码进行优化,例如提取公共模块、压缩代码等。 3. 代码拆分:Webpack 支持代码拆分,可以将应用程序的代码分割成多个小的代码块(chunk),并按需加载。这样可以避免将整个应用程序的代码一次性加载到浏览器,提高了页面加载速度和用户体验。 4. 资源管理:Webpack 还可以管理应用程序中的其他资源,例如图片、字体等文件。通过加载器(loader),可以对这些资源文件进行处理和优化,例如压缩、合并等。 总的来说,Webpack 在浏览器端能够通过代码依赖分析、转换和优化、代码拆分以及资源管理等功能把应用程序的代码打包成一个或多个优化过的文件,以提高应用的性能和用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值