JQuery中区分模拟点击事件和用户点击事件 24 September 2012
使用JQuery,我们可以自定义了事件函数,如:
$("#foo").click(function(e){
//do work
});
我们还可以模拟点击等事件的发生,如$("#foo").click()
有的时候我们需要区分这种模拟事件和真正的用户事件。
-
方法一
我们可以通过传递的参数e来判断是否是真正的用户点击,如果是用户点击事件,对象e将有clientX, clientY, pageX, pageY等属性,并且均是数字。我们也可以检查originalEvent属性,代码如下:
$("#foo").click(function(e){
if(e.hasOwnProperty('originalEvent'))
// Probably a real click.
else
// Probably a fake click.
});
-
方法二
我们也可以在定义事件函数的时候指定额外的参数,通过此参数来判断,详见trigger api
$("#foo").click(function(e, from){
if(from == null) from = 'User';
// rest of your code
});
$('#foo').trigger('click', ['Trigger']);
reference
本文出自夜惊心的博客,转载请保留出处blog comments powered by Disqus