javascript跨浏览器的属性判断方法_javascript技巧
程序员文章站
2022-05-17 21:39:00
...
今天在写代码的时候发现一个很容易出错的地方。当我们在声明变量时,常常会因为不同的 browser 有不同的 API 定义,然后用以下的写法来判断哪一个属性,例如:
用||来检查要用哪一个 attribute。
不过要小心 javascript 的值当成条件时的判断。
例如:
这段代码希望 screenLeft 会回传 window.screenLeft ,而在 firefox 会回传 window.screenX。
但是如果 screenLeft 刚好等於 0 的时候,就会进入||之后的条件了,接著就 gg 了。
复制代码 代码如下:
var fullscreenElement = document.mozFullScreenElement || document.webkitFullscreenElement || document.fullscreenElement;
用||来检查要用哪一个 attribute。
不过要小心 javascript 的值当成条件时的判断。
例如:
复制代码 代码如下:
var sLeft = window.screenLeft || window.screenX; //firefox use screenX
console.log(sLeft);
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;
if( !window.hasOwnProperty('screenLeft')) sLeft = window.screenX;
上一篇: jQuery的实现原理的模拟代码 -5 Ajax_jquery
下一篇: 下拉透明菜单
推荐阅读
-
JavaScript自动点击链接 防止绕过浏览器访问的方法
-
使用JavaScript判断用户输入的是否为正整数(两种方法)
-
JavaScript中Number.MAX_VALUE属性的使用方法
-
JavaScript中length属性的使用方法
-
JavaScript中判断为整数的多种方式及保留两位小数的方法
-
JavaScript 判断iPhone X Series机型的方法
-
firefox怎么禁用javascript和flash?火狐浏览器屏蔽js的方法
-
JavaScript实现动态添加、移除元素或属性的方法分析
-
JavaScript中判断两个字符串是否相等的方法
-
javascript动态改变img的src属性图片不显示的解决方法