javascript跨浏览器的属性判断方法_Javascript教程-查字典教程网
javascript跨浏览器的属性判断方法
javascript跨浏览器的属性判断方法
发布时间:2016-12-30 来源:查字典编辑
摘要:今天在写代码的时候发现一个很容易出错的地方。当我们在声明变量时,常常会因为不同的browser有不同的API定义,然后用以下的写法来判断哪一...

今天在写代码的时候发现一个很容易出错的地方。当我们在声明变量时,常常会因为不同的 browser 有不同的 API 定义,然后用以下的写法来判断哪一个属性,例如:

复制代码 代码如下:var fullscreenElement = document.mozFullScreenElement || document.webkitFullscreenElement || document.fullscreenElement;

用||来检查要用哪一个 attribute。

不过要小心 javascript 的值当成条件时的判断。

例如:

复制代码 代码如下:var sLeft = window.screenLeft || window.screenX; //firefox use screenX

console.log(sLeft);

这段代码希望 screenLeft 会回传 window.screenLeft ,而在 firefox 会回传 window.screenX。

但是如果 screenLeft 刚好等於 0 的时候,就会进入||之后的条件了,接著就 gg 了。

因此建议在值的判断还是正统一点用 hasOwnProperty 或 typeof 来判断会比较精準。

复制代码 代码如下:var sLeft = window.screenLeft;

if( !window.hasOwnProperty('screenLeft')) sLeft = window.screenX;

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类