浅谈JavaScript中浏览器兼容的问题

浏览器兼容性问题是在实际开发中容易忽略而又最重要的一部分 。我们在讲老版本浏览器兼容问题之前 , 首先要了解什么是能力检测 , 它是来检测浏览器有没有这种能力 , 即判断当前浏览器是否支持要调用的属性或者方法 。下面做了一些简短的介绍 。
1、innerText 和 innerContent
1)innerText 和 innerContent 的作用相同
2)innerText IE8之前的浏览器支持
3)innerContent 老版本的Firefox支持
4)新版本的浏览器两种方式都支持

浅谈JavaScript中浏览器兼容的问题

文章插图
2、获取兄弟节点/元素的兼容性问题
1)兄弟节点 , 所有浏览器都支持
①nextSibling 下一个兄弟节点 , 可能是非元素节点;会获取到文本节点
【浅谈JavaScript中浏览器兼容的问题】②previousSibling 上一个兄弟节点 , 可能是非元素节点;会获取到文本节点
2)兄弟元素 , IE8以前不支持
①previousElementSibling 获取上一个紧邻的兄弟元素 , 会忽略空白
②nextElementSibling 获取下一个紧邻的兄弟元素 , 会忽略空白
浅谈JavaScript中浏览器兼容的问题

文章插图

浅谈JavaScript中浏览器兼容的问题

文章插图

浅谈JavaScript中浏览器兼容的问题

文章插图

浅谈JavaScript中浏览器兼容的问题

文章插图

浅谈JavaScript中浏览器兼容的问题

文章插图
3、array.filter();
// 使用指定的函数测试所有元素 , 并创建一个包含所有通过测试的元素的新数组
浅谈JavaScript中浏览器兼容的问题

文章插图
4、array.forEach();
// 遍历数组
浅谈JavaScript中浏览器兼容的问题

文章插图
5、注册事件
浅谈JavaScript中浏览器兼容的问题

文章插图

浅谈JavaScript中浏览器兼容的问题

文章插图
6、事件对象
1)事件参数e , 就是事件对象 , 标准的获取方式
btn.onclick = function(e) { }
2)e.eventPhase 事件阶段 , IE8以前不支持
3)e.target 始终是触发事件的对象(点击的按钮)
i)IE8以前 srcElement
ii)浏览器兼容
var target = e.target || window.event.srcElement;
浅谈JavaScript中浏览器兼容的问题

文章插图
7、获取鼠标在页面上的位置
①在可视区域中的位置: e.clientX e.clientY
②在文档中的位置:
i) e.pageX e.pageY
ii)浏览器兼容
浅谈JavaScript中浏览器兼容的问题

文章插图


8、获取页面滚动的距离
浅谈JavaScript中浏览器兼容的问题

文章插图


9、取消文本的选择
浅谈JavaScript中浏览器兼容的问题

文章插图
以上这篇浅谈JavaScript中浏览器兼容的问题就是小编分享给大家的全部内容了 , 希望能给大家一个参考 , 也希望大家多多支持我们网 。

    推荐阅读