现在的位置: 首页 > web前端 > 正文

JS事件有哪些兼容性

2020年06月10日 web前端 ⁄ 共 1374字 ⁄ 字号 评论关闭

  事件(Event)即为用户的动作,例如:用户点击鼠标,产生onclick事件;按下键盘,产生onkeyDown事件;改变输入框的值,产生onchange事件,当在元素上点击时,弹出警告框,内容为鼠标在屏幕上的横坐标。下面学步园小编来讲解下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事件有哪些兼容性”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.