发布时间:2022-08-10 文章分类:编程知识 投稿人:李佳 字号: 默认 | | 超大 打印

JS兼容问题总结

“标准浏览器”和“低版本浏览器(IE)”兼容写法

一、浏览器卷去的高度和宽度

var scrollTop = document.documentElement.scrollTop || document.body.scrollTop
var scrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft

JS兼容问题总结

二、处理事件对象兼容

    function (e) {
var e = e || window.event
}

e--标准浏览器;

window.event--低版本浏览器(IE);

三、 按键兼容

事件对象里面有一个叫做 keyCode 的属性,
表示你按下的是哪一个按键,但是是以编码的形式给你
特性: FireFox < 20的版本不支持
火狐低版本使用 which 属性

    //兼容:
var code = e.keyCode || e.which

四、阻止事件传播的兼容(冒泡和捕获)

标准浏览器:e.stopPropagation()
IE低版本: e.cancelBubble = true

兼容:
方式1if (e.stopPropagation) { } else { }
方式2:try {} catch (e) { }(尝试第一个大括号里面的代码,如果报错,执行后面的)

五、处理事件目标兼容

目标准确触发事件的那个元素,在事件对象里面有一个属性叫做 target 表示本次事件触发的时候,准确触发的元素我们叫做事件目标
IE低版本不支持
IE低版本使用 srcElement

处理兼容
var target = e.target || e.srcElement

target

  • target 这个属性是事件对象里面的属性,表示你点击的目标

  • 当你触发点击事件的时候,你点击在哪个元素上,target 就是哪个元素

  • 这个 target 也不兼容,在 IE 下要使用 srcElement

    <body>
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
<script>
var oUl = docuemnt.querySelector('ul')
oUl.addEventListener('click', function (e) {
e = e || window.event
var target = e.target || e.srcElement
console.log(target)
})
</script>
</body>

六、获取元素非行间样式兼容

getComputedStyle(非IE使用)

  • 语法:window.getComputedStyle(元素, null).要获取的属性

  • 第二个参数不写的时候默认是null,表示是一个正常元素

  • 第二个参数可以写'after' || 'before',表示获取伪元素的样式

<style>
div {
width: 100px;
}
</style>
<body>
<div>
<p>我是一个 p 标签</p>
</div>
<script>
var oDiv = document.querySelector('div')
console.log(window.getComputedStyle(oDiv).width) // 100px
console.log(window.getComputedStyle(oDiv).height) // 100px
</script>
</body>
//这个方法获取行间样式和非行间样式都可以

currentStyle(IE使用)

语法:元素.currentStyle.要获取的属性

    <style>
div {
width: 100px;
}
</style>
<body>
<div>
<p>我是一个 p 标签</p>
</div>
<script>
var oDiv = document.querySelector('div')
console.log(oDiv.currentStyle.width) // 100px
console.log(oDiv.currentStyle.height) // 100px
</script>
</body>

七、 阻止浏览器默认行为的兼容

标准浏览器: e.preventDefault()

IE 低版本: e.returnValue = false

    //兼容:
   方式1: if (e.preventDefault) {} else {}
   方式2: try {} catch (err) {}
   方式3: return false (大部分情况下是可以用的)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<a href="https://www.baidu.com">阻止浏览器默认行为</a>
<script>
// 获取元素
var a = document.getElementsByTagName('a')[0]
a.onclick = function (e) {
e = e || window.event
console.log('我被点击了')
// 阻止默认事件
// e.preventDefault()
// IE 低版本
// e.returnValue = false
return false
}
//禁止框选文本
window.onselectstart = function () {
return false
}
// 右键单击事件
window.oncontextmenu = function () {
console.log('右键单击了')
return false
}
</script>
</body>
</html>

八、事件监听的绑定兼容

    oDiv.addEventListener('click', function () {
console.log('我是第一个事件')
}, false)
oDiv.addEventListener('click', function () {
console.log('我是第二个事件')
}, false)

注意: 事件类型的时候不要写 on,点击事件就是 click,不是 onclick;

    oDiv.attachEvent('onclick', function () {
console.log('我是第一个事件')
})
oDiv.attachEvent('onclick', function () {
console.log('我是第二个事件')
})

注意: 事件类型的时候要写 on,点击事件就行 onclick;

两个方式的区别

九、事件解绑

    var x = document.getElementById("myDIV");
if (x.removeEventListener) {                   // // 所有浏览器,除了 IE 8 及更早IE版本
x.removeEventListener("mousemove", myFunction);
} else if (x.detachEvent) {                   // IE 8 及更早IE版本
x.detachEvent("onmousemove", myFunction);
}