温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JS事件都有哪些兼容性

发布时间:2021-08-25 11:48:46 来源:亿速云 阅读:123 作者:chen 栏目:开发技术

本篇内容介绍了“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事件都有哪些兼容性”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js
AI