关于兼容IE的一些策略
--css 盒子模型下的 box-sizing 属性,只兼容到ie8;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
-o-box-sizing: border-box;
-ms-box-sizing: border-box;
box-sizing: border-box;
--ie10及以下的img会有默认的黑色边框
解决:在指定img设置边框属性 border-style:none\9;
--ie6双边距bug: 当一个元素使用浮动时,且其同时设置了外边距margin并其边距的方向与浮动的方向一致时,这个时候在ie6下,就会出现这个双边距bug,即边距是实际设置的2倍;
解决方案:很简单,在该元素的css类里面写上 display:inline;
(原因是,css float属性浮动的元素,不管他们之前是什么,会被变成 block 属性,而ie6不知为何,在渲染float 及 元素为block的时候会让其边距翻倍,因此,我们只管将其属性再次改回 inline 即可)
--ie8及以下不支持border-radius
解决方案:在这里,我们可以引入PIE.htc (http://www.zhangxinxu.com/study/js/pie.htc 参考张鑫旭博客)
这种方案是有局限性的:
1.定位问题
为目标元素设置position:relative或是设置祖先元素position:relative并赋予一个z-index值(不可为-1)。
2. 相当路径的问题
IE浏览器的behavior 属性是相对于HTML文档而言的,与CSS其他的属性不一样,不是相对于CSS文档而言的。因此我们在写路径的时候要写成绝对路径;
3. 缩写的问题
不支持border-top-left-radius这种写法
4. 提供正确的Content-Type
要想让IE浏览器支持htc文件,需要一个有着”text/x-component” 字样的content-type 头部,否则,会忽视behavior。(这一步感觉不是特别需要,我个人在ie8尝试了下没有加这个字样照样可以使用);
给个例子:
将以上的pie.htc保存至css目录下;然后在css对应的类里面写上
behavior:url(/dedecms/templets/default/style/pie.htc);/*绝对路径*/

ie6以上 各个版本的兼容 hack 技术
针对ie 的hack 其实有好多个符号,但是,全部记住这个我个人觉得没多大必要,反而会更乱;我列举了一下4种符号,记住一下4种符号就好了,然后按需求组合一下就可以实现了;
_ :选择IE6及以下。
* :选择IE7及以下。
\9:选择IE6及以上
\0:选择IE8及以上
最后再来说说css 的 一个概念 :haslayout
haslayout是IE渲染引擎的一个内部组成部分,IE使用布局概念来控制元素的尺寸和定位,在理想情况下,所有元素都控制自己的尺寸和定位;IE开发团队将“布局”用于实际需要的元素上,从而减少性能开销;拥有布局的元素负责本身及其子元素的尺寸和定位。没有布局的元素,那么它的尺寸和位置由最近的拥有布局的祖先元素控制。
它能用来干嘛,在这里,别的我不说了,我就举2个比较经典的例子。
1、清除浮动
clearfix{
*zoom:1
}
clearfix:after{
content:"";
display:table;
clear:both;
}
大家有没有发现,*zoom:1;
这个到底是什么原理?这是因为ie6/7不支持伪元素,用:after{}无效,故在ie6/7时又加了个hack,zoom:1;
这个zoom,重点是能起到触发haslayout属性,从而修复高度塌陷的问题;
2、display:inline-block 在ie6/7 不支持
按照对haslayout的理解,我们可以通过在ie6/7 的时候做些特殊的处理
解决方案:
在对应的css类里面添加 “*display:inline; *zoom:1”;
原理就是在ie6/7下为inline元素添加zoom:1,让它触发haslayout,从而有了自己的布局,可以计算自己的框高;于是就达到了类似 display:inline-block 的效果了
关于兼容IE的一些策略的更多相关文章
- 通过iframe引入另外一个项目中的html片段到项目中,解决样式,高度,兼容等问题的策略
<!--尾部开始--> <iframe src="http://172.16.24.11:9000/cartoon-web/footer_new" m ...
- 谷歌的Android Q到底有哪些新特性及变更?
Android Q 隐私更改相关介绍 存储范围变更 Android Q 改变了应用程序访问设备外部存储上文件的方式. 通过使用更细粒度的媒体特定权限替换以前的 READ_EXTERNAL_STORAG ...
- Magento 架构基础知识概述
Megento 架构基础知识概述 Magento整合了面向对象的基于PHP的应用程序的核心架构原则.这些一般原则的综合讨论既有在线的,也有印刷形式.以下讨论主要关注这些主题如何直接应用于Magento ...
- 【DotNetNuke介绍】
简介 DotNetNuke(以下简称DNN)的最终目的是创建一个门户的框架平台,这个平台可以为开发者增添模块搭建应用程序提供坚实的可靠的支持.应用程序的一个关键的功能就是数据存取..NET Frame ...
- Keras Conv1d 参数及输入输出详解
Conv1d(in_channels,out_channels,kernel_size,stride=1,padding=0,dilation=1,groups=1,bias=True) filter ...
- 『动善时』JMeter基础 — 20、JMeter配置元件【HTTP Cookie管理器】详细介绍
目录 1.HTTP Cookie管理器介绍 2.HTTP Cookie管理器界面详解 3.JMeter中对Cookie的管理 (1)Cookie的存储 (2)Cookie的管理策略 4.补充:Cook ...
- Qt 中的二进制兼容策略(简而言之就是地址不能变,剩下的就是让地址不变的技巧)
本文翻译自 Policies/Binary Compatibility Issues With C++ 二进制兼容的定义 如果程序从一个以前版本的库动态链接到新版本的库之后,能够继续正常运行,而不需要 ...
- CSS3与页面布局学习总结(八)——浏览器兼容与前端性能优化
一.浏览器兼容 1.1.概要 世界上没有任何一个浏览器是一样的,同样的代码在不一样的浏览器上运行就存在兼容性问题.不同浏览器其内核亦不尽相同,相同内核的版本不同,相同版本的内核浏览器品牌不一样,各种运 ...
- 深入浏览器兼容 细数jQuery Hooks 属性篇
关于钩子:http://www.cnblogs.com/aaronjs/p/3387906.html 本章的目的很简单,通过钩子函数更细节的了解浏览器差异与处理方案, 版本是2.0.3所以不兼容ie6 ...
随机推荐
- iOS 事件传递(Touch事件)
先总说如下: 1.当手指触摸到屏幕时,会产生UITouch对象和UIEvent对象. 2.这两个对象产生后会被传递到UIApplication管理的一个事件队列中. 3.再有UIApplication ...
- getAttribute、setAttribute、removeAttribute
1.函数语法 elementNode.attributes:属性返回包含被选节点属性的 NamedNodeMap. elementNode.getAttribute(name):方法通过名称获取属性的 ...
- struts2笔记(3)
关于回显: 如果是int型,默认就会回显为0,如果不想让回显,则Integer就好 //**************************************声明式验证************* ...
- 响应者链条,如何获取最佳的点击view 以及内部实现
事件的产生与传递 事件是如何产生与传递的? 当发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中. UIApplication会从时间队列中取出最前面的时间,并将事件 ...
- java 标签库(核心,xml,sql ,国际化,函数)
java标签库分分为上述几种,一般经常使用的是核心和函数,接下来会分别讲解这几种,和常见的用法. 一般标签库会和el表达式一起使用,所以在学习标签库前最后也学习下el表达式的使用. 导入后展开 可以从 ...
- SpringMVC后台接收list类型的数据的实现方式
一.背景 最近在做一些东西的时候,遇到一个需要Springmvc后台接收list类型数据的需求,几经辗转才完美解决了这个问题,今天记下来方便以后使用,也分享给需要的小伙伴们~ 二.实现方式 1.实现方 ...
- rman恢复报ORA-27039
查看资源限制: AIX修改参数文件/etc/security/limits 如下: 重新su到用户下即可生效
- Xamarin 与VS2015RC(xamarin 3.11.450) 报空指针错误。
在Android开发中发现的一个“初步认为是调试器的bug”. 于早些时候发布在公司论坛上,传送门: http://www.newlifex.com/showtopic-1400.aspx 使用vs2 ...
- 初识node.js
Node.js不是一种语言:不是框架:也不是工具.它是用于运行基于JavaScript应用程序的运行时环境.
- godaddy1美元虚拟主机
第一个域名是免费的 ftp连接:新建ftp账号,把配置文件导入相应的ftp客户端(user名可能有问题,使用非加密的模式) SSH连接: 1.开启SSH连接:http://godaddy.idcspy ...