`

ie6在布局上要注意的一些问题-20130927

 
阅读更多
1. 设置position: relative
将一个元素设置为”position:relative”可以解决很多问题,特别是遇到隐藏的或对齐诡异的盒子。显然,需要注意,因为绝对定位的子节点可能会因此重新定位。

2. 将浮动元素设置为display:inline
具有margin属性的浮动元素可能引起著名的IE6双倍margin问题,为一个元素指定margin-left为5px,但是IE6中实际上却表现为10px。”display:inline”将解决这个问题。

3. 将一个元素设置为hasLayout
很多IE6(和IE7)的渲染问题可以通过设置元素的hasLayout来解决。 这是一个IE内部属性(IE隐藏的,更多关于haslayout的资料,可以参阅这里),用来确定相对于其他元素,内容是如何布局和定位的。如果要设置一个inline元素(比如一个链接)为block元素,或者是应用透明效果,设置hasLayout也可能是必须的。

最简单的设置hasLayout的方法是为CSS设置一个高度或宽度(zoom也可以用,但是zoom并不是CSS标准的一部分)。设置实际尺寸,但是问题是这是不现实的,可能需要使用”height:1%”。如果父元素并没有设置高度,该元素的实际高度并不受影响,而且这个时候hasLayout已经被启用。

4. 修正重复文字bug
复杂的布局可以触发在浮动元素的最后一些字符可能出现在出现在清除元素下面的bug。这里有几个解决方法,有些是完美的,但是做一些反复试验也是必须的:

确保所有的元素使用”display:inline;”
在最后一个元素上使用一个”margin-right:-3px;”

在容器的最后元素使用一个空的div(它也有必要设置宽度为90%或类似宽度。)
访问 positioniseverything.net 查看该问题的完整介绍。

5. 在可点击和悬停的元素上只使用标签IE6只认识对a标签的CSS hover效果。可以在基于JavaScript的组件内使用他们来控制,以使他们保持键盘的可操作性。是有一些可替代的选择,但是标签比其它方案更可靠。

6. 使用!important 或高级选择器来区分IE6不使用传统Hack或在额外文件中的条件CSS的方法,写出特别针对IE6的可行的代码也还是有可能的。比如最小高度可以通过这段代码来定义:

#element {
  min-height: 20em;
  height: auto !important; /* 所有浏览器都理解这段代码 */
  height: 20em; /* IE6 错误的使用这个值 /*
} 


IE6 不理解min-height并错误的用20em覆盖”auto”高度,但是,如果内容需要更多的空间的话,它会自动增加高度。

另外一个可选的方法是使用高级选择器

#element {
  min-height: 20em;
  height: 20em;
}

/* IE6 无视下面的代码*/
#element[id] {
   height: auto;
} 


7. 避免百分比单位
百分比会把IE搞糊涂的。除非可以确切的控制每一个父元素的大小,才可能做到最佳预防。可以通过!important在其他浏览器中继续使用百分比

body {
  margin: 2% 0 !important;
  margin: 20px 0; /* IE6 only */
} 



8. 重构的代码
经常发生的事情是,修正bug要比重新考虑一个布局问题要花更长的时间。对HTML做些小改动和一些简单的CSS常常更有效。
分享到:
评论

相关推荐

    js解决IE6~8的响应式布局问题

    响应式布局,理想状态是,对PC/移动各种终端进行响应。媒体查询的支持程度是IE9+以及其他现代的浏览器,但是IE8在市场当中仍然...关于respond.js的使用,有一些需要注意的地方,一旦不注意,在IE6-8中就无法显示出来。

    《CSS标准网页布局开发指南》附赠光盘

    其中使用的浏览器及其版本为IE6.0、IE7.0、Firefox2.0。其中具体实例使用的浏览器版本,请参照相关章节的内容部分。 -----------------------------硬件环境--------------------------------------- 无特殊要求...

    css兼容性问题总结笔记

    自己遇见的一些常见的css兼容性问题。和css hack 自己总结出来后生产pdf文档带书签的。 ...12. IE6中居中布局问题 7 13. IE6 Png图片不透明问题 7 14. 移除超级链接的虚线 7 15. 隐藏水平滚动条 7

    页面前端布局的兼容问题

    目前市面上流行的浏览器有目前主要主流的浏览器有IE6、IE7、IE8、IE9、foxfire浏览器、google浏览器、opera浏览器、safari浏览器和基于IE内核的(如:360)等其他的浏览器,这些浏览器在处理一个相同的页面时,表现...

    Jquery拖动窗格保存布局Cookie源码

    技术特点: 本示例主要源自自己最近要做的一个项目需要用到,但是百度了下觉得这个和我的相近,但是下载下来后发现各兼容性都不好,于是花了几个小时整理并升级了这个功能示例...浏览器兼容:IE6 、chrome,更多请自测

    TSDQQ响应式布局网址导航系统带后台 v20150428 UTF-8版.zip

    4、程序在服务器上的反应速度,跟服务器上网站数量和硬件配置及国内外IP和带宽有关。 5、首页频道开启 请在后台【管理分类 - (设置)首页(开启)状态】 即可增加首页列表内容。 6、默认只设置了2个,为了避免...

    ExtAspNet v2.2.1 (2009-4-1) 值得一看

    -修正了使用IFrameUrl的Tab在切换过程中会重复加载的问题,这是一个在v2.1.6引入的问题(feedback:eroach)。 -修正了启用AutoPostBack的Grid,其RowClick会覆盖LinkButtonField, HyperLinkField, CheckBoxField的...

    IE6 两个div有间隙的问题(IE 3px bug)

    已存在解决方法:利用float和margin的负值偏移...要注意的是,使用overflow的时候,一定要定义width,百分比或者具体值都可以.)即可,这样在IE6和IE7中都能有效的显示。 实现:这里也采用上面参考中的例子,其中例子中的

    CSS布局口诀CSS布局口诀

    一、IE边框若显若无,须注意,定是高度设置已忘记; 二、; 三、 ...十、列表横向排版,列表代码须紧靠,空隙自消须铭记。

    CSS浏览器兼容性常见问题总结大全(推荐)

    DIV+CSS网页布局这是一种趋势,我也开始顺应这股趋势了,不过在使用DIV+CSS网站设计的时候,应该注意css样式兼容不同浏览器问题,特别是对完全使用DIV+CSS设计的网页,就应该更注意IE6 IE7 FF对CSS样式的兼容. ...

    golden-layout:适用于Web应用程序的多窗口布局管理器

    金色布局 请注意,该项目目前正在进行较大的维护和重构,我们的目标是在2020年上半年发布2.0版本。产品特点全触摸支持本机弹出窗口完全主题化全面的API 强大的持久性适用于IE8 +,Firefox,Chrome 响应式设计安装/...

    CSS文集

    利用CSS的Expression自定义属性来实现表格的OnMouseOver 特效 需要掌握...important标记区别Firefox和IE6 DIV+CSS页面布局中注意的问题以及常用的CSS使用方法 网页布局基础-XHTML与CSS基础 CSS命名规则

    ExtAspNet_v2.3.2_dll

    -实际上IE7下所以的回发都慢,原因是客户端的Base64编码速度慢,已经使用encodeURIComponent来代替Base64编码。 -俄语翻译(feedback:vbelyaev)。 +2010-06-30 v2.3.1 -ExtAspNet控件将不在依赖ViewState,...

    TSDQQ响应式布局网址导航系统带后台UTF-8版

    4、程序在服务器上的反应速度,跟服务器上网站数量和硬件配置及国内外IP和带宽有关。 5、首页频道开启 请在后台【管理分类 - (设置)首页(开启)状态】 即可增加首页列表内容。 6、默认只设置了2个,为了避免大家...

    css入门笔记

    4、spread:阴影的大小,指定要在基础阴影上扩充出来的大小距离,取值以px为单位的数值 5、color:阴影颜色 6、inset:将默认外阴影转为内阴影 在第一位 4、轮廓 轮廓指的是边框的边框,绘制于边框外的线条。 ...

    马良神笔cms网站管理系统 v1.1002 beta.zip

    4.首个 全任意坐标可拖拽式模板布局编辑器,拖拽完自动切图生成相对定位div代码 5.http://你的域名/index.php/yun 为云模块列表页,可以共享云模块 6.马良神笔cms是全开源的php 的cms系统,而且基于我们的云...

    网群企业网站管理系统 v2.1.zip

    一、修正IE6上的部分显示问题。 二、后台操作习惯优化。 三、进一步规范命名规则。 2012-06-28 1.4 发布 一、修改顶部loog和名称图片样式。 二、修正订单不成功的bug。 三、规范命名规则。 四、模板细节...

    Collector资料收集管理器

    5、修正从菜单功能中导进文件数据对不上的问题; 6、修正添加无内容文件时的BUG; 7、添加只读打开功能(要设置密码); 1.7版本 1、修改数据库格式,添加一些数据库信息,程序会把旧数据库自动转换到新版本的...

    Justify:一款实现inline-block元素两端对齐布局的javascript插件(a javascript plug-in implementation inline-block elements full-justified layout)

    元素均分宽度、两端自适应对齐的布局在移动web项目中的需求还是挺多的,使用inline-block元素,配合text-align:justify,再注意处理好一些细节问题,便可以在现代浏览器上实现两端对齐,但是最后一行的处理却是个...

Global site tag (gtag.js) - Google Analytics