微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

<div class="jb51code">
<pre class="brush:js;">
(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,fn ); // 这种做法具有侵入性,多个类似的代码会相互覆盖,可采用深度复制方式调用原$.fn.bind方法
}
})(jQuery);

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

原文地址:https://www.jb51.cc/jquery/51320.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐