使用jQuery委派Hammer.js事件

时间:2012-04-17 12:50:34

标签: jquery events touch hammer.js

我已经开始使用Hammer.js(https://github.com/eightmedia/hammer.js),这是一个很棒的小脚本,但我不确定如何使用jQuery的.on()事件处理程序委派事件。

我在这里设置了一个小jsfiddle示例:http://jsfiddle.net/will/3dUKu/1/

var i = 0;
// How would I apply hammer to this situation?
$('nav').on('click', 'button', function() {
    $('<button id="' + i + '">Extra button ' + i + ' (' + $(this).attr('id') + ')</button>').appendTo('nav');
    i++;
});

1 个答案:

答案 0 :(得分:3)

不知道您是否找到了问题的答案。解决方案很简单,有两个部分。首先,因为你试图使用jQuery调用,你应该使用Hammer的jQuery插件版本。可以在以下位置找到当前版本的jQuery插件:

http://eightmedia.github.io/hammer.js/dist/jquery.hammer.min.js

第二部分是你需要使用Hammer的方法和对象选择。您可以通过在选择器和绑定之间插入Hammer调用来完成此操作。像这样:

jQuery对象:

$('nav').on('click', 'button', function(){ 
    /* ... */ 
});

jQuery Hammer对象:

$('nav').hammer().on('click', 'button', function(){
    /* ... */
});

就是这样......