目前市场上浏览器种类很多,不同浏览器的内核也不尽相同,所以各个浏览器对网页的解析存在一定的差异。所以也导致了浏览器兼容性的问题出现,市面上主流的浏览器内核主要有下列几种:
(1)Trident
代表作品:IE因为IE捆绑在Windows中,所以占有极高的市场份额,又称IE内核或是MSHTML,此内核只能应用于windows平台,且是不开源的。
(2)Gecko
代表作品Mozilla Firefox是开源的,它的最大优势是跨平台,能在Microsoft Windows、Linux和MacOS X等主要操作系统上运行。
(3)Webkit
代表作品Safari、Chrome , 是一个开源项目。
(4)Presto
代表作品Opera ,Presto是由Opera Software开发的浏览器排版引擎。它也是世界上公认的渲染速度最快的引擎。
(5)Blink
由Google和Opera Software开发的浏览器排版引擎,2013年4月发布。
国内主流的浏览器也大多用的这几种内核
下面是一些常见的兼容性问题
1、html和css部分
1)默认高度(IE6):在IE6及以下版本中,部分块元素拥有默认高度(低于18px高度)。
解决方法:给元素添加声明:font-size:0;或者给元素添加声明:overflow:hidden。
2)当Ie6及更低版本浏览器在解析浮动元素时,会错误地把浮向边的边界加倍显示。
解决方法:给浮动元素添加声明:display:inline。
3)表单元素行高对齐方式不一致
解决方法:给表单元素添加声明:float:left。
4)按钮元素默认大小及样式不一致
解决方法:
①:用a标签模拟;
②:如果这个按钮是一个图片,直接把图片作为按钮的背景图即可。
5)透明属性
IE浏览器写法:filter:alpha(opacity=数值);取值范围 1-100(IE8以下);
兼容其他浏览器写法:opacity:数值;(数值的取值范围0-1,0.1,0.2,0.3-----0.9)。
6)父元素里有块元素,如果给子元素添加添加margin-top,父元素会下来。
解决方法:
①:给父元素添加overflow:hidden;
②:给子元素添加float;
③:给父元素加边框;
④:给父元素加padding-top.
7)边距重叠问题:当相邻两个元素都设置了margin 边距时,margin 将取最大值,舍弃最小值。
解决方法:为了不让边重叠,可以给子元素增加一个父级元素,并设置父级元素为overflow:hidden。
8)div中的图片间隙,在块元素中插入图块状元素片时,有时图片会将块元素下方撑大三像素。
解决方法:给img标签添加声明:display:block。
2、JavaScript部分
1)停止冒泡
<script>
var btn = document.getElementById("btn");
btn.onclick = function(e) {
alert("点击了按钮");
var evt = e || window.event;//此处也是兼容IE
if(event && event.stopPropagation)
{
event.stopPropagation(); //W3C
}
else
{
event.cancelBubble = true; // 兼容IE
}
}
</script>
2)返回按键的键盘代码
event.keycode || event.which;
3)阻止默认行为的方式
if (evt.preventDefault) {
evt.preventDefault();//W3C
}else{
evt.returnValue='false';//兼容IE
}
4)事件监听
添加事件监听器:addEventListener(事件名,处理函数,布尔值);
IE情况下添加:attachEvent(事件名,处理函数);(IE情况下事件名加on)
移除事件监听器:removeEventListener(事件名,处理函数);
IE情况下移除:detachEvent(事件名,处理函数);(IE情况下事件名加on)