移动端上下滑动事件之--坑爹的touch.js
下面的方法,不知道是操作方法不对还是啥. 在 zepto.js 里面加那一段代码不起作用
百度的 touch.js 是可以用的,但是使用方式 和 zepto有点不一样.
解决方案:参照这个链接地址
http://www.cnblogs.com/zhongxia/p/5410478.html
==========================================================
转:http://blog.csdn.net/minidrupal/article/details/39611605?utm_source=tuicool&utm_medium=referral
移动端页面的盛行,微信的便利的页面推广等等,让越来越多的css3效果和html5在手机端大放异彩。
于是乎,各式各样的简约酷炫的html5页面层出不穷,最多的就是视差滚动+css3动画。
接下来就说说自己在搞这些页面里面碰到的一个小问题-------zepto.js里面,坑爹的touch.js的上下滑动(swipe)事件失效。
在举例之前,先科普一下如何在pc端,查看html5页面在各种分辨率的手机的展示情况。
最常见的就是利用谷歌的手机模拟器。
步骤1:打开谷歌浏览器,按F12.
步骤2:然后按截图里面的步骤,选择各种分辨率,在刷新一下页面,就可以看到效果。
注:各种手机的选择
开始描述问题之前,先提供几个网址,
让你们试试能不能看到效果。
- (function($) {
- var options, Events, Touch;
- options = {
- x: 20,
- y: 20
- };
- Events = ['swipe', 'swipeLeft', 'swipeRight', 'swipeUp', 'swipeDown', 'tap', 'longTap', 'drag'];
- Events.forEach(function(eventName) {
- $.fn[eventName] = function() {
- var touch = new Touch($(this), eventName);
- touch.start();
- if (arguments[1]) {
- options = arguments[1]
- }
- return this.on(eventName, arguments[0])
- }
- });
- Touch = function() {
- var status, ts, tm, te;
- this.target = arguments[0];
- this.e = arguments[1]
- };
- Touch.prototype.framework = function(e) {
- e.preventDefault();
- var events;
- if (e.changedTouches) events = e.changedTouches[0];
- else events = e.originalEvent.touches[0];
- return events
- };
- Touch.prototype.start = function() {
- var self = this;
- self.target.on("touchstart",
- function(event) {
- event.preventDefault();
- var temp = self.framework(event);
- var d = new Date();
- self.ts = {
- x: temp.pageX,
- y: temp.pageY,
- d: d.getTime()
- }
- });
- self.target.on("touchmove",
- function(event) {
- event.preventDefault();
- var temp = self.framework(event);
- var d = new Date();
- self.tm = {
- x: temp.pageX,
- y: temp.pageY
- };
- if (self.e == "drag") {
- self.target.trigger(self.e, self.tm);
- return
- }
- });
- self.target.on("touchend",
- function(event) {
- event.preventDefault();
- var d = new Date();
- if (!self.tm) {
- self.tm = self.ts
- }
- self.te = {
- x: self.tm.x - self.ts.x,
- y: self.tm.y - self.ts.y,
- d: (d - self.ts.d)
- };
- self.tm = undefined;
- self.factory()
- })
- };
- Touch.prototype.factory = function() {
- var x = Math.abs(this.te.x);
- var y = Math.abs(this.te.y);
- var t = this.te.d;
- var s = this.status;
- if (x < 5 && y < 5) {
- if (t < 300) {
- s = "tap"
- } else {
- s = "longTap"
- }
- } else if (x < options.x && y > options.y) {
- if (t < 250) {
- if (this.te.y > 0) {
- s = "swipeDown"
- } else {
- s = "swipeUp"
- }
- } else {
- s = "swipe"
- }
- } else if (y < options.y && x > options.x) {
- if (t < 250) {
- if (this.te.x > 0) {
- s = "swipeLeft"
- } else {
- s = "swipeRight"
- }
- } else {
- s = "swipe"
- }
- }
- if (s == this.e) {
- this.target.trigger(this.e);
- return
- }
- }
- })(window.jQuery || window.Zepto);
Author: Alone
Antroduction: 高级前端开发工程师
Sign: 人生没有失败,只有没到的成功。
移动端上下滑动事件之--坑爹的touch.js的更多相关文章
- 移动端上下滑动事件之--坑爹的touch.js
原文 http://blog.csdn.net/minidrupal/article/details/39611605 移动端页面的盛行,微信的便利的页面推广等等,让越来越多的css3效果和htm ...
- 移动端 uni-app 滑动事件 精确判断手指滑动方向
移动端根据手指滑动操作判断滑动方向 设计思路: 1.根据移动端touchstart和touchend方法获取手指触摸屏幕的开始坐标和结束坐标 2.根据两个坐标计算与水平方向的夹角 3.根据夹角判断当前 ...
- Html5 移动端 触摸滑动事件
以下代码经过测试 没有问题 且可以循环滑动 <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"& ...
- 【css】用css巧妙实现移动端横向滑动展示功能
前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用cs ...
- 用css巧妙实现移动端横向滑动展示功能
前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用cs ...
- 原生js移动端滑动事件
移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...
- 移动端js手指滑动事件初体验
今天在公司遇到做一个移动端手指滑动的效果,刚開始用了swiper.js插件发现效果不好(文字存在模糊效果).后来查了一些资料,自己手写了一个使用原生js写的滑动效果. 以下直接上代码: <!do ...
- 移动端H5开发 (滑动事件)
最近一直在做手机App H5的开发,在开发过程中,经常会遇到很多滑动事件,写个demo,分享自己的一些写法.(如写的不好,轻喷!) 直接贴代码 html css代码 <!DOCTYPE html ...
- 移动端touch滑动事件监听
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
随机推荐
- Web--CSS控制页面(link与import方式区别)
先了解: [1] “Table”和“DIV”这两个网页元素诞生的目的不同,首先Table诞生的目的是为了存储数据,而DIV诞生的目的就是为了架设页面结构 W3C,是World Wide ...
- 云存储(Swift+Keystone)部署策略
Swift是OpenStack的对象存储模块,Keystone是OpenStack的权限验证模块.可以于这两个模块搭建一个较为完善的云存储系统. 1.官方方案 云存储的服务器分三种类型: 验证节点 A ...
- AE文档保存
private void barButtonItem4_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)//保存 { ...
- MVC 之var与dynamic
如果你用MVC写过程序,那么你应该知道ViewBag这个用于前后台的数据传递工具,那么你是否对ViewBag的用法感到过疑惑呢? ViewBag.Mode1l=new object(); ViewBa ...
- 哪个类可用于处理 Unicode?
A. InputStreanReader的构造函数: InputStreamReader(InputStream in) 创建一个使用默认字符集的 InputStreamReader ...
- Docker网络实践运用
Docker 容器网络概述 要构建具有安全的一致行为的 Web 应用程序,可以使用 Docker 网络特性.根据定义,网络为容器实现了完全隔离.因此,控制应用程序所在的网络很重要.Docker 容器网 ...
- Maven配置私服仓库
首先就是,最基本的打开maven的配置文件,上面是我自己的习惯,多留一个以备不坏 打开setting配置文件,来修改路径(本人不习惯将所有软件放在C盘,一般都是单独存放盘) 接下来就是公司给你的账户和 ...
- python学习之老男孩python全栈第九期_day029知识点总结——configparser模快、logging模块
一. configparser模块 生成文档 import configparser config = configparser.ConfigParser() config[', 'Compressi ...
- parseInt OR Number进行数字的转换
在js中,字符串转为数字类型是比较常见的,平时用的比较多的是parseFloat和parseInt这两个方法.当然,除了这个方法之外还有一个Number:都是转为数字类型,有什么差别? 可以简单的说N ...
- 浏览器根对象navigator之客户端检测
Navigator的5个主要属性: appName:Web浏览器的名称 appVersion:浏览器的版本号和其他版本信息 userAgent:浏览器在它的USER-AGENT HTTP标题中发送的字 ...