jQuery实现获取绑定自定义事件元素的方法
作者:bea
本文实例讲述了jQuery实现获取绑定自定义事件元素的方法。分享给大家供大家参考,具体如下: (function ($) { // 自定义itemtab事件$.fn.bind = function(types, data, fn) { // 重载jQuery.fn.bind方法,用来截获绑定自定义事件的元素 if(typeof types == 'string' && 'itemtab' == types) { var itemTouchStart =
本文实例讲述了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程序设计有所帮助。
有用 | 无用
(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程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- java必学必会之static关键字
- 详解页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题
- 继续学习javascript闭包
- 解决js页面滚动效果scrollTop在FireFox与Chrome浏览器间的兼容问题的方法
- jQuery 1.9.1源码分析系列(十五)之动画处理
- ztree获取选中节点时不能进入可视区域出现BUG如何解决
- jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween
- JS使用post提交的两种方式
- JavaScript测试工具之Karma-Jasmine的安装和使用详解
- 五种js判断是否为整数类型方式
- JavaScript学习笔记之检测客户端类型是(引擎、浏览器、平台、操作系统、移动设备)
- 基于javascript代码检测访问网页的浏览器呈现引擎、平台、Windows操作系统、移动设备和游戏系统
- 学习JavaScript设计模式(代理模式)
- 全面解析Bootstrap图片轮播效果
- 谈谈基于iframe、FormData、FileReader三种无刷新上传文件的方法
- 解决JavaScript数字精度丢失问题的方法
- Javascript实现检测客户端类型代码封包
- javascript学习小结之prototype
- 简单实现JS对dom操作封装