没有合适的资源?快使用搜索试试~ 我知道了~
解决浏览器兼容问题的CSS语法技巧大全.doc
需积分: 9 16 下载量 76 浏览量
2011-06-10
23:39:45
上传
评论
收藏 385KB DOC 举报
温馨提示
试读
64页
我们再网站的制作中,常常会为了浏览器的兼容问题,而绞尽脑汁的想解决方案,现在我在整理一个相应问题的解决方案的文档,很不错的资源,绝对强大的资源
资源推荐
资源详情
资源评论
让 CSS 兼容 IE 和 Firefox 的技巧集合
标签: Firefox CSS 技巧 兼容 2009-05-15 11:54
来源:http://mcnasty.blogbus.com/logs/37425275.html
让 CSS 兼容 IE 和 Firefox 的技巧集合
CSS 对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得
也不是难事,从网上收集了 IE7,6 与 Fireofx 的兼容性处理方法并整理了一下。对于 web2.0
的过度,请尽量用 xhtml 格式写代码,而且 DOCTYPE 影响 CSS 处理,作为 W3C 的标准,
一定要加 DOCTYPE 声明。
CSS 技巧
1.div 的垂直居中问题
vertical-align:middle; 将行距增加到和整个 DIV 一样高 line-height:200px; 然后插入文字,
就垂直居中了。缺点是要控制内容不要换行
2. margin 加倍的问题
设置为 float 的 div 在 ie 下设置的 margin 会加倍。这是一个 ie6 都存在的 bug。解决方
案是在这个 div 里面加上 display:inline; (margin-left:加倍,个人见解)
例如:
<#div id=”imfloat”>
相应的 css 为
#imfloat{
float:left;
margin:5px;/*IE 下理解为 10px*/
display:inline;/*IE 下再理解为 5px*/}
3.浮动 ie 产生的双倍距离
#box{ float:left; width:100px; margin:0 0 0 100px; //这种情况之下 IE 会产生 200px 的距离
display:inline; //使浮动忽略}
这里细说一下 block 与 inline 两个元素:block 元素的特点是,总是在新行上开始,高度,宽
度,行高,边距都可以控制(块元素);Inline 元素的特点是,和其他元素在同一行上,不可控制(内
嵌元素);
#box{ display:block; //可以为内嵌元素模拟为块元素 display:inline; //实现同一行排列的
效果 diplay:table;
4 IE 与宽度和高度的问题
IE 不认得 min-这个定义,但实际上它把正常的 width 和 height 当作有 min 的情况来使。
这样问题就大了,如果只用宽度和高度,正常的浏览器里这两个值就不会变,如果只用
min-width 和 min-height 的话,IE 下面根本等于没有设置宽度和高度。
比如要设置背景图片,这个宽度是比较重要的。要解决这个问题,可以这样:
#box{ width: 80px; height: 35px;}html>body #box{ width: auto; height: auto; min-width:
80px; min-height: 35px;}
5.页面的最小宽度
min-width 是个非常方便的 CSS 命令,它可以指定元素最小也不能小于某个宽度,这样
就能保证排版一直正确。但 IE 不认得这个,而它实际上把 width 当做最小宽度来使。为了
让这一命令在 IE 上也能用,可以把一个<div> 放到 <body> 标签下,然后为 div 指定一个
类,然后 CSS 这样设计:
#container{ min-width: 600px; width:expression(document.body.clientWidth < 600?
"600px": "auto" );}
第一个 min-width 是正常的;但第 2 行的 width 使用了 Javascript,这只有 IE 才认得,
这也会让你的 HTML 文档不太正规。它实际上通过 Javascript 的判断来实现最小宽度。
6.DIV 浮动 IE 文本产生 3 象素的 bug
左边对象浮动,右边采用外补丁的左边距来定位,右边对象内的文本会离右边对象的
左边有 3px 的间距.
#box{ float:left; width:800px;}
#left{ float:left; width:50%;}
#right{ width:50%;}
*html #left{ margin-right:-3px; //这句是关键}
<div id="box">
<div id="left"></div>
<div id="right"></div>
</div>
处理前
7.IE 捉迷藏的问题
当 div 应用复杂的时候每个栏中又有一些链接,DIV 等这个时候容易发生捉迷藏的问
题。
有些内容显示不出来,当鼠标选择这个区域是发现内容确实在页面。 解决办法:对
#layout 使用 line-height 属性 或者给#layout 使用固定高和宽。页面结构尽量简单。
8.float 的 div 闭合;清除浮动;自适应高度;
①例如:< #div id=”floatA” > <#div id=”floatB” ><#div id=”NOTfloatC” >这里的
NOTfloatC 并不希望继续平移,而是希望往下排。(其中 floatA、floatB 的属性已经设置为
float:left;)
这段代码在 IE 中毫无问题,问题出在 FF。原因是 NOTfloatC 并非 float 标签,必须将
float 标签闭 合 。 在 <#div class=”floatB”> <#div class=”NOTfloatC”> 之间加 上 < #div
class=”clear”>这个 div 一定要注意位置,而且必须与两个具有 float 属性的 div 同级,之间
不能存 在 嵌 套关系 , 否 则会产 生 异 常。并 且 将 clear 这 种样式 定 义为为如 下 即 可:
.clear{ clear:both;}
②作为外部 wrapper 的 div 不要定死高度,为了让高度能自动适应,要在 wrapper 里面加
上 overflow:hidden; 当包含 float 的 box 的时候,高度自动适应在 IE 下无效,这时候应该触
发 IE 的 layout 私有属性(万恶的 IE 啊!)用 zoom:1;可以做到,这样就达到了兼容。
例如某一个 wrapper 如下定义:
.colwrapper{ overflow:hidden; zoom:1; margin:5px auto;}
③对于排版,我们用得最多的 css 描述可能就是 float:left.有的时候我们需要在 n 栏的
float div 后面做一个统一的背景,譬如:
<div id=”page”>
<div id=”left”></div>
<div id=”center”></div>
<div id=”right”></div>
</div>
比如我们要将 page 的背景设置成蓝色,以达到所有三栏的背景颜色是蓝色的目的,但是
我们会发现在 FF 里随着 left center right 的向下拉长,而 page 居然保存高度不变,问题来了,如
上图.原因在于 page 不是 float 属性,而我们的 page 由于要居中,不能设置成 float,所以我们应
该这样解决,再嵌入一个 float left 而宽度是 100%的 DIV 解决效果如图二。
<div id=”page”>
<div id=”bg” style=”float:left;width:100%;background-color:blue;”>
<div id=”left”></div>
<div id=”center”></div>
<div id=”right”></div>
</div>
</div>
或者直接在 page 的样式里添加一个 overflow:hidden;即可,属于自己的解决办法。效果如图
3。
④万能 float 闭合(非常重要!)
关于 clear float 的原理可参见 [How To Clear Floats Without Structural Markup],将以下代
码加入 Global CSS 中,给需要闭合的 div 加上 class="clearfix" 即可,屡试不爽.
/* Clear Fix */
.clearfix:after { content:"."; display:block; height:0; clear:both; visibility:hidden; }
.clearfix { display:inline-block; }
/* Hide from IE Mac */
.clearfix {display:block;}
/* End hide from IE Mac */
/* end of clearfix */
或者这样设置:.hackbox{ display:table; //将对象作为块元素级的表格显示}
8.高度不适应
高度不适应是当内层对象的高度发生变化时外层高度不能自动进行调节,特别是当内
层对象使用 margin 或 padding 时。
例:
#box {background-color:#eee; }
#box p {margin-top: 20px;margin-bottom: 20px; text-align:center; }
<div id="box">
<p>p 对象中的内容</p>
</div>
解 决 方 法 : 在 P 对 象 上 下 各 加 2 个 空 的 div 对 象 CSS 代
码:.1{height:0px;overflow:hidden;}或者为 DIV 加上 border 属性。
10 .IE6 下为什么图片下有空隙产生
解决这个 BUG 的方法也有很多,可以是改变 html 的排版,或者设置 img 为 display:block
或者设置 vertical-align 属性为 vertical-align:top bottom middle text-bottom 都可以解决.
11.如何对齐文本与文本输入框
加上 vertical-align:middle;
<style type="text/css">
<!--
input {
width:200px;
height:30px;
border:1px solid red;
vertical-align:middle;
}
-->
</style>
12.web 标准中定义 id 与 class 有什么区别吗
一.web 标准中是不容许重复 ID 的,比如 div id="aa" 不容许重复 2 次,而 class 定义的是类,
理论上可以无限重复, 这样需要多次引用的定义便可以使用他.
二.属性的优先级问题
ID 的优先级要高于 class,看上面的例子
三.方便 JS 等客户端脚本,如果在页面中要对某个对象进行脚本操作,那么可以给他定义
一个 ID,否则只能利用遍历页面元素加上指定特定属性来找到它,这是相对浪费时间资源,远
远不如一个 ID 来得简单.
13. LI 中内容超过长度后以省略号显示的方法
此方法适用与 IE 与 OP 浏览器
<style type="text/css">
<!--
li {
width:200px;
white-space:nowrap;
text-overflow:ellipsis;
-o-text-overflow:ellipsis;
overflow: hidden;
}
-->
</style>
14.为什么 web 标准中 IE 无法设置滚动条颜色了
解决办法是将 body 换成 html
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<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>
剩余63页未读,继续阅读
资源评论
happyWorkXu
- 粉丝: 5
- 资源: 32
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功