A5下载 - 努力做内容最丰富最安全的下载站!

A5站长下载站

当前位置:A5下载 > 编程开发 > 网站开发 > jQuery实现获取绑定自定义事件元素的方法

jQuery实现获取绑定自定义事件元素的方法

时间:2015-12-03 17:05作者:fang人气:54

本文实例讲述了jQuery实现获取绑定自定义事件元素的方法。分享给大家供大家参考,具体如下:

(function ($) { // 自定义itemtab事件

$.fn.bind = function(types, data, fn) { // 重载jQuery.fn.bind方法,用来截获绑定自定义事件的元素

if(typeof types == 'string' && 'itemtab' == types) {

var itemTouchStart = -1; // touchstart位置

var itemTouchMove = -1; // touchend位置,值为-1时表示未触发

var itemTriggerDistance = 0; // 拖动距离阀值,若大于该值则为拖动列表,若小于等于该值则为点击列表项

var itemMoved = false; // 列表是否为拖动状态

$(this).bind('touchstart', function (event) {

if(!event.originalEvent.touches.length) return true;

itemMoved = false;

itemTouchStart = event.originalEvent.touches[0].pageX; // 记录起始位置

}).bind('touchmove', function (event) {

if(!event.originalEvent.touches.length) return true;

itemTouchMove = event.originalEvent.touches[0].pageX; // 当前拖动位置

//console.log('touchmove:', itemTouchStart, itemTouchMove, itemMoved);

if(Math.abs(itemTouchMove - itemTouchStart) > itemTriggerDistance) {

itemMoved = true; // 列表被拖动

}

}).bind('touchend', function (event) {

//console.log('itemMoved:', itemMoved);

if(itemMoved) { // 列表被拖动过,非点击操作

return true;

}

$(this).trigger('itemtab'); // 触发自定义事件

});

}

return this.on( types, null, data, fn ); // 这种做法具有侵入性,多个类似的代码会相互覆盖,可采用深度复制方式调用原$.fn.bind方法

}

})(jQuery);

希望本文所述对大家jQuery程序设计有所帮助。

标签jQuery,实现,获取,绑定,自定义,事件,元素,方法,本

相关下载

查看所有评论+

网友评论

网友
您的评论需要经过审核才能显示

公众号