常见浏览器兼容问题与解决方案

1. 浏览器兼容问题一:不同浏览器的标签默认的外边距和内边距不同
(1) 问题症状:在浏览器中随便写几个标签,在不加css样式控制的情况下,各自的margin和padding差异较大。
(2) 解决方案:css中添加 *{margin:0;padding:0}
(3) 备注:这是最常见也是最容易解决的一个浏览器兼容问题,几乎所有的css文件开头都会添加 *{margin:0;padding:0};

2. 浏览器兼容问题二:块级元素float后,又有横行margin的情况下,在IE6显示margin比设置的大
(1) 问题症状:在IE6中,后面的一块会被挤到下一行。
(2) 解决方案:在float的元素的css样式中,加入display:inline将其转化为行内属性。
(3) 备注:这是比较常用的div+css布局,div是一个典型的块级元素,横向布局时使用div float来实现,横向的间距如果用margin实现,就会出现浏览器的兼容问题。

3. 浏览器兼容问题三:设置较小高度的元素(一般小于10px),在IE6,IE7中高度超出自己设置的高度
(1) 问题症状:在IE6,IE7中,这个元素的高度不受控制,超出自己设置的高度。
(2) 解决方案:给超出高度的元素设置overflow:hidden,或者设置line-height:(小于自己设置的高度)。
(3) 这个问题出现的原因是:这种问题一般出现在设置小圆角背景的元素里。在IE8之前的浏览器中,都会给元素设置一个最小默认的行高的高度。即使这个元素是空的,这个元素的高度还是会达到默认的行高。

4. 浏览器兼容问题四:行内属性标签,设置display:block后采用float布局,又有横行margin的情况,IE6间距bug
(1) 问题症状:IE6的间距超过自己设置的间距。
(2) 解决方案:在display:block后继续添加css样式,display:inline;display:table。
(3) 备注:行内属性标签,为了设置宽高,我们需要设置display:block。在采用float布局并有横向的margin后,在IE6下,就具有了浏览器兼容问题二。不过因为本身是行内元素,加上display:inline后,高度就不可设了。然后就需要在display:inline后加入display:table。

5. 浏览器兼容问题五:图片默认有边距
(1) 问题症状:几个img标签放在一起时,有些浏览器会有默认的边距,在css中添加*{margin:0;padding:0}仍然无用。
(2) 解决方案:使用float属性为img布局。
(3) img标签是行内属性标签,所以只要不超出容器宽度,img标签都会排成一列,但是部分浏览器会存在img标签之间有间距,所以使用float属性。(其实,使用父margin也能解决,但负margin本身就容易引起浏览器兼容问题,所以不推荐使用。)

6. 浏览器兼容问题六:标签最低高度设置min-height不兼容
(1) 问题症状:min-height本身就是一个不兼容的css属性,所以设置min-height会出现浏览器兼容问题。
(2) 解决方案:如果我们要设置一个标签的最小高度为200px,需要进行的css样式为:{min-height:200px;height:auto !important;height:200px;overflow:visible;}
(2) 在B/S系统前端开发时,会出现这种需求。当内容小于一个值(如300px)时,容器的高度为300px;当内容高度大于这个值时,容器高度被撑高,而不是出现滚动条。

7. 浏览器兼容问题七:css样式的透明度设置
在IE中使用:filter:alpha(opacity:0);来设置元素的透明度;
在Firefox中,直接使用opacity:0;
解决兼容性问题,就是在css样式中将2个样式都写上。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值