本篇内容介绍了“JS事件都有哪些兼容性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
JS事件有哪些兼容性
这种做法在FireFox、Chrome、Safari等遵循W3C规范的浏览器下是没有问题的,唯独在IE(暂时仅限于8.0以下版本,8.0以上版本笔者未曾测试)下是行不通的,IE采用了一种非标准的方式,并不是将事件作为函数参数传入,而是将事件作为window对象的event属性:window.event、window.event.screenX...
所以,我们在写代码的时候要照顾到IE,做好事件的兼容。
下面是笔者给出的一个简单的兼容示例,该示例并没有去判断浏览器,仅仅使用了一个小技巧。
点击我将获得屏幕坐标
document.getElementById("demo").onclick=function(e)
{
var e=e||event;
alert(e.screenX);
}
注意,不要将var e=e||event;写成var e=event||e;,这在FireFox下会提示错误,FireFox无法处理未声明未赋值的变量event。
这里大家可能有疑虑,为什么是var e=e||event;,为什么是或运算(||),这样的结果只能是e=true或者e=false?
笔者告诉大家,在大多数编程语言里,或运算(||)返回的并不只是true或者false,而是返回第一个不为false的变量的值,例如:
var a=5||6;//a=5
var b=0||5;//b=5
var c=false||"www.itxueyuan.com";//c="www.itxueyuan.com"
var e=e||event;//e为用户事件
好,这几个例子,笔者相信大家一定明白了,上面对事件兼容的巧妙处理,也就迎刃而解了。
例如,某个升级的IE版本支持将事件作为函数参数传入,抛弃了将事件作为window的属性,而我们的代码,恰恰是这个样子的:
JS事件有哪些兼容性
if((/ie/i).test(navigator.userAgent))
document.getElementById("demo").onclick=function()
{
alert(window.event.screenX);
}
else
document.getElementById("demo").onclick=function(e)
{
alert(e.screenX);
}
那么在升级的IE浏览器上运行就会产生错误了。
最后,梳理了思路,再把上面的代码重复一遍。
点击我将获得屏幕坐标
document.getElementById("demo").onclick=function(e)
{
var e=e||event;
alert(e.screenX);
}
“JS事件都有哪些兼容性”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。