浏览器兼容常见的一些问题

       目前市场上浏览器种类很多,不同浏览器的内核也不尽相同,所以各个浏览器对网页的解析存在一定的差异。所以也导致了浏览器兼容性的问题出现,市面上主流的浏览器内核主要有下列几种:

(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)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值