Zepto插件:手机网站封装好的touch事件js
来源: 阅读:6074 次 日期:2015-03-18 11:43:26
温馨提示: 小编为您整理了“Zepto插件:手机网站封装好的touch事件js”,方便广大网友查阅!

最近公司开发手机网站,本人主要负责前端这块的工作,考虑到jquery脚本库体质大的问题,选择用Zepto脚本框架,对于手机网站,滑动屏幕事件是频繁用到的,所以经过一小段时间的研究,本人做了一个基于Zepto.js的插件,主要是对手机网站 上划,下滑,左划,右滑事件的封装。具体代码如下:

(function($) {

$.fn.touchwipe = function(settings) {

var config = {

min_move_x: 50,

min_move_y: 20,

wipeLeft: function() { },

wipeRight: function() { },

wipeUp: function() { },

wipeDown: function() { },

preventDefaultEvents: false

};

if (settings) $.extend(config, settings);

this.each(function() {

var startX;

var startY;

var isMoving = false;

var directionLocked = null;

function cancelTouch() {

this.removeEventListener('touchmove', onTouchMove);

startX = null;

isMoving = false;

directionLocked = false;

}

function onTouchMove(e) {

if(config.preventDefaultEvents) {

e.preventDefault();

}

if(isMoving) {

var x = e.changedTouches ? e.changedTouches[0].clientX: e.clientX;

var y = e.changedTouches ? e.changedTouches[0].clientY: e.clientY;

var dx = startX - x;

var dy = startY - y;

var absDistX = Math.abs(dx);

var absDistY = Math.abs(dy);

if (directionLocked === "y") {

return

} else {

if (directionLocked === "x") {

e.preventDefault()

} else {

absDistX = Math.abs(dx);

absDistY = Math.abs(dy);

if (absDistX < 4) {

return

}

if (absDistY > absDistX ) {

dx = 0;

directionLocked = "y";

return

} else {

e.preventDefault();

directionLocked = "x"

}

}

}

if(absDistX >= config.min_move_x) {

cancelTouch();

if(dx > 0) {

config.wipeLeft();

}

else {

config.wipeRight();

}

}

}

}

function onTouchStart(e)

{

if (e.touches.length == 1) {

startX = e.changedTouches ? e.changedTouches[0].clientX: e.clientX;

startY = e.changedTouches ? e.changedTouches[0].clientY: e.clientY;

isMoving = true;

directionLocked = false;

this.addEventListener('touchmove', onTouchMove, false);

}

}

if ('ontouchstart' in document.documentElement) {

this.addEventListener('touchstart', onTouchStart, false);

}

});

return this;

};

})(Zepto);

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map