分类分类
更新时间:2026-02-18 20:58:42作者:fang
本文实例讲述了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程序设计有所帮助。
相关
归墟战纪策略游戏262.92 MBv3.95802026-02-14
下载爆裂老奶策略游戏209.43 MBv1.0.112026-02-14
下载超能下蛋鸭策略游戏395.4 MBv1.2.82026-02-14
下载你好盒子实用工具12.1 MBv2.2.852026-02-14
下载我在峡谷当牛马休闲益智87.95 MBv0.7.12026-02-14
下载抽卡监狱2策略游戏190.75 MBv1.4.92026-02-14
下载Campus社交通讯94.36 MBv1.19.02026-02-14
下载冒险传奇角色扮演141.73 Mv9991.12026-02-14
下载心动次元app社交通讯43.96 Mv1.0.1.32026-02-14
下载致亲爱的我角色扮演1.63Gv1.02026-02-14
下载狼伴侣游戏手机版冒险游戏155.6 Mv1.02026-02-14
下载Loclike社交通讯169.08 Mv2.2.112026-02-14
下载










