js常见兼容性问题?

1) 滚动条:

document.documentElement.scrollTop || document.body.scrollTop;


2) 获取非行内样式兼容

高版本浏览器为:window.getComputedStyle(obj,伪类)["属性"]  不获取伪类的时候可以不写或者写false/null;

低版本浏览器为:元素 (obj).currentStyle.属性(attr) 

if(window.getComputedStyle){
    return window.getComputedStyle(obj,false)[attr]      
}else{
    return obj.currentStyle.attr
}        

获取非行内样式(兼容问题)

    function getStyle(obj,attr){             //获取非行间样式,obj是对象,attr是值
        if(obj.currentStyle){                //针对ie获取非行间样式
            return obj.currentStyle[attr];
        }else{
            return getComputedStyle(obj,false)[attr];   //针对非ie
        };
    };

3) 网页可视区域兼容

window.innerHeight || document.documentElement.clientHeight

window.innerWidth || document.documentElement.clientWidth

4)事件对象兼容

var e = e || window.event

5)阻止事件冒泡兼容

e.stopPropagation ? e.stopPropagation() : e.cancelBubble = true 

6)阻止默认行为兼容

e.preventDefult ? e.preventDefult() : e.returnValue = false

7)事件监听兼容

obj.addEventListener("事件去掉on",function(){},布尔值)

obj.attachEvent("事件带on",function(){})  //IE

8)事件目标对象兼容

var t = event.target || event.srcElement;

10)获取键盘的按键

IE8以及以下版本不兼容which

var x = event.which || event.keyCode  ||  var x = e.which || e.keyCode

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值