常见的浏览器兼容问题和常见的CSSbug以及对应的解决方式(面试常用)

1 浏览器的五个内核

•Trident (MSHTML)

•Gecko

•Presto

•Webkit (Safari内核,Chrome内核原型,它是苹果公司自己的内核,也是苹果的Safari浏览器使用的内核)

•Blink (由Google和Opera Software开发的浏览器排版引擎)。

2 各内核的代表作

​ Trident: IE、Maxthon(遨游)、腾讯 、Theworld世界之窗、360浏览器。代表作品IE,因为IE捆绑在Windows中,所以占有极高的市场份额,又称IE内核或是MSHTML,此内核只能应用于windows平台,且是不开源的。

​ Gecko:代表作品Mozilla Firefox、Netscape 6以后版本 是开源的,它的最大优势是跨平台,能在Microsoft Windows、Linux和MacOS X等主要操作系统上运行。

​ Webkit : 代表作品Safari、Chrome 、傲游浏览器3, 是一个开源项目。

​ Presto : 代表作品Opera(前内核),Presto是由Opera Software开发的浏览器排版引擎。它也是世界上公认的渲染速度最快的引擎。Opera现已改用Google Chrome的Blink内核。

​ Blink :由Google和Opera Software开发的浏览器排版引擎,2013年4月发布。

3 浏览器内核的组成

1、主要分成两部分:渲染引擎和JS引擎。

2、渲染引擎:负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等)、以及计算网页的显示方式、然后会输出至显示器或打印机。浏览器的内核的不同对于网页的语法解释会有不同、所以渲染的效果也不相同。

3、JS引擎则解析和执行javascript来实现网页的动态效果。

最开始渲染引擎和JS引擎并没有区分得很明确,后来JS引擎越来越独立,内核九倾向于只指渲染引擎。

4 为什么会出现浏览器兼容问题?

​ 由于各大主流浏览器由不同的厂家开发,所用的核心架构和代码也很难重合,这就为各种莫名其妙的Bug(代码错误)提供了温床。再加上各大厂商出于自身利益考虑而设置的种种技术壁垒,都让CSS应用起来比想象得要麻烦。浏览器的兼容问题是我们必须去克服的。

5 CSSbug和CSShack
5.1 CSSBug、CSSHack和Filter
  1. CSS Bug: CSS样式在各浏览器中解析不一致的情况,或者说CSS样式在浏览器中不能正确显示的问题称为CSS bug.

  2. CSS Hack: CSS中,Hack是指一种兼容CSS在不同浏览器中正确显示的技巧方法,因为它们都属于个人对CSS代码的非官方的修改,或非官方的补丁。有些人更喜欢使用patch(补丁)来描述这种行为。

  3. Filter:表示过滤器的意思,它是一种对特定的浏览器或浏览器组显示或隐藏规则或声明的方法。本质上讲,Filter是一种用来过滤不同浏览器的Hack类型。

使用Hack带来的一些副作用

降低了CSS代码的可读性,增加了代码的负担。

*使用CSS Hack和 Filter通常有两种方法:

1)一种是利用浏览器自身的Bug,来隐藏或显示样式或声明;

2)另一种是利用浏览器对CSS支持的不完善,如对某些规则或语法还没有形成支持,来隐藏或显示样式。

5.2 常见的CSSbug及对应的CSShack

1)图片间隙

A) div中的图片间隙(该bug出现在所有浏览器中)
描述:在div中插入图片时,图片会将div下方撑大三像素。
hack:将转为块状元素,给添加声明:display:block;

B)当图片横着排的时候,图片跟图片之间存在一定的间距
hack:img{float:left;}

2) dt,li中图片间隙

hack: 将转为块状元素,给添加声明:display:block;

3)图片在IE浏览器上有蓝色的边框(加在a标签里)

hack:给img的边写成0;img{border:0;}

4)表单元素距离顶部间距不一致(IE,MOZ,C,O,S)

描述:表单元素距离顶部的距离不一致

hack:给表单元素添加声明:float:left;

5)按钮元素默认大小不一

描述:各浏览器中按钮元素大小不一致

hack1: 统一大小/(用a标记模拟)

hack2:input外边套一个标签,在这个标签里写按钮的样式,把input的边框去掉。

hack3:如果这个按钮是一个图片,直接把图片作为按钮的背景图即可。

6)百分比bug

描述:在IE6及以下版本中在解析百分比时,会按四舍五入方式计算从而导致50%加50%大于100%的情况。
(也会受系统影响)

hack: 给右面的浮动元素添加声明:
clear:right;

7)鼠标指针bug

描述:cursor属性的hand属性值只有IE9以下浏览器识别,其它浏览器不识别该声明,cursor属性的pointer属性值IE6.0以上版本及其它内核浏览器都识别该声明。

hack: 如统一某元素鼠标指针形状为手型,

应添加声明:cursor:pointer;

8)子元素没设置任何浮动,设置了margin-top属性后,会错误的把margin-top的属性值添加给父元素.

hack1:给父元素添加overflow:hidden;声明。

*:如果子元素设置了浮动属性也不会出现这个问题。

9)当给li中的a转成block;并且有height,并有float的时候,li中没设置浮动会出现阶梯显示,hack:同时给li加float;

10)input的type类型是text的时候,提示信息用value表示,如果设置了input的高度,在其他浏览器上显示的value的内容是垂直居中的,但是在ie6上是在顶部的,解决的方法就是给input添加一个行高等于它的高度。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值