下面的方法,不知道是操作方法不对还是啥.  在 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:然后按截图里面的步骤,选择各种分辨率,在刷新一下页面,就可以看到效果。

注:各种手机的选择

开始描述问题之前,先提供几个网址,

让你们试试能不能看到效果。

 
 
 
能在谷歌模拟器看到不同分辨率的效果。截几个图看一下。
 
 
 
 
好了,进入正题。
做这类html5页面,最主要的事件就是滑动事件。
分别是左右滑动和上下滑动。
说到这里,可能很多人都会脱口而出。用zepto.js就可以简单搞定啦。
 
我也是这么想的。于是很快的,就用zepto.js加上它的touch组件,touch.js实现了相应的效果。
在谷歌浏览器的模拟器也能很好的兼容。
 
后来放上测试服务器,用手机一看,问题来了!!!!
手机上的uc,腾讯,微信自带浏览器,QQ自带浏览器器,苹果系统的浏览器,安卓的原生浏览器,上下滑动的事件都失效!
只有谷歌浏览器是有事件相应的。坑爹啊!!!!
 
zepto.js用的人估计不少,想不到touch.js竟然兼容这么差,还是我打开的方式不对?!!!
这里就不贴这个js里面的代码出来了。
 
遇到问题,只好寻求其他解决方法。
解决方法先列几个吧。
第一个:jquery mobile里面的touch组件。
第二个:百度的童鞋们实现的touch.js.网址也贴一下吧:http://touch.code.baidu.com/
 
第三个就是技术群里面的一些童鞋提供,亲测是有效的:
 
[javascript] view plain copy

  1. (function($) {
  2. var options, Events, Touch;
  3. options = {
  4. x: 20,
  5. y: 20
  6. };
  7. Events = ['swipe', 'swipeLeft', 'swipeRight', 'swipeUp', 'swipeDown', 'tap', 'longTap', 'drag'];
  8. Events.forEach(function(eventName) {
  9. $.fn[eventName] = function() {
  10. var touch = new Touch($(this), eventName);
  11. touch.start();
  12. if (arguments[1]) {
  13. options = arguments[1]
  14. }
  15. return this.on(eventName, arguments[0])
  16. }
  17. });
  18. Touch = function() {
  19. var status, ts, tm, te;
  20. this.target = arguments[0];
  21. this.e = arguments[1]
  22. };
  23. Touch.prototype.framework = function(e) {
  24. e.preventDefault();
  25. var events;
  26. if (e.changedTouches) events = e.changedTouches[0];
  27. else events = e.originalEvent.touches[0];
  28. return events
  29. };
  30. Touch.prototype.start = function() {
  31. var self = this;
  32. self.target.on("touchstart",
  33. function(event) {
  34. event.preventDefault();
  35. var temp = self.framework(event);
  36. var d = new Date();
  37. self.ts = {
  38. x: temp.pageX,
  39. y: temp.pageY,
  40. d: d.getTime()
  41. }
  42. });
  43. self.target.on("touchmove",
  44. function(event) {
  45. event.preventDefault();
  46. var temp = self.framework(event);
  47. var d = new Date();
  48. self.tm = {
  49. x: temp.pageX,
  50. y: temp.pageY
  51. };
  52. if (self.e == "drag") {
  53. self.target.trigger(self.e, self.tm);
  54. return
  55. }
  56. });
  57. self.target.on("touchend",
  58. function(event) {
  59. event.preventDefault();
  60. var d = new Date();
  61. if (!self.tm) {
  62. self.tm = self.ts
  63. }
  64. self.te = {
  65. x: self.tm.x - self.ts.x,
  66. y: self.tm.y - self.ts.y,
  67. d: (d - self.ts.d)
  68. };
  69. self.tm = undefined;
  70. self.factory()
  71. })
  72. };
  73. Touch.prototype.factory = function() {
  74. var x = Math.abs(this.te.x);
  75. var y = Math.abs(this.te.y);
  76. var t = this.te.d;
  77. var s = this.status;
  78. if (x < 5 && y < 5) {
  79. if (t < 300) {
  80. s = "tap"
  81. } else {
  82. s = "longTap"
  83. }
  84. } else if (x < options.x && y > options.y) {
  85. if (t < 250) {
  86. if (this.te.y > 0) {
  87. s = "swipeDown"
  88. } else {
  89. s = "swipeUp"
  90. }
  91. } else {
  92. s = "swipe"
  93. }
  94. } else if (y < options.y && x > options.x) {
  95. if (t < 250) {
  96. if (this.te.x > 0) {
  97. s = "swipeLeft"
  98. } else {
  99. s = "swipeRight"
  100. }
  101. } else {
  102. s = "swipe"
  103. }
  104. }
  105. if (s == this.e) {
  106. this.target.trigger(this.e);
  107. return
  108. }
  109. }
  110. })(window.jQuery || window.Zepto);
总结:为什么要把这个作为一篇博客发出去,就是因为之前碰到这个问题的时候,问度娘问谷歌都很少答案。所以把这个小问题说出来,让碰到类似问题的童鞋,能够有一些启发。
 
 
 
 

Author: Alone
Antroduction: 高级前端开发工程师
Sign: 人生没有失败,只有没到的成功。

移动端上下滑动事件之--坑爹的touch.js的更多相关文章

  1. 移动端上下滑动事件之--坑爹的touch.js

    原文   http://blog.csdn.net/minidrupal/article/details/39611605 移动端页面的盛行,微信的便利的页面推广等等,让越来越多的css3效果和htm ...

  2. 移动端 uni-app 滑动事件 精确判断手指滑动方向

    移动端根据手指滑动操作判断滑动方向 设计思路: 1.根据移动端touchstart和touchend方法获取手指触摸屏幕的开始坐标和结束坐标 2.根据两个坐标计算与水平方向的夹角 3.根据夹角判断当前 ...

  3. Html5 移动端 触摸滑动事件

    以下代码经过测试  没有问题 且可以循环滑动 <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"& ...

  4. 【css】用css巧妙实现移动端横向滑动展示功能

    前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用cs ...

  5. 用css巧妙实现移动端横向滑动展示功能

    前言:记得以前处理移动端横向滑动展示都是去用js去解决的,要用js进行蛮多处理,要算li的宽度,然后还要用js设置ul盒子的宽度,又要设置最大滑动距离,最小滑动距离等等.......但是现在发现用cs ...

  6. 原生js移动端滑动事件

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  7. 移动端js手指滑动事件初体验

    今天在公司遇到做一个移动端手指滑动的效果,刚開始用了swiper.js插件发现效果不好(文字存在模糊效果).后来查了一些资料,自己手写了一个使用原生js写的滑动效果. 以下直接上代码: <!do ...

  8. 移动端H5开发 (滑动事件)

    最近一直在做手机App H5的开发,在开发过程中,经常会遇到很多滑动事件,写个demo,分享自己的一些写法.(如写的不好,轻喷!) 直接贴代码 html css代码 <!DOCTYPE html ...

  9. 移动端touch滑动事件监听

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

随机推荐

  1. Linux多线程 - 基本操作

    0. 线程 vs 进程 何为线程?线程即轻量级进程,如何理解轻量级这个概念? 我们知道,Linux的资源分为用户空间资源和内核空间资源: 用户空间资源:用来存放用户自定义的一些数据,用户可直接控制: ...

  2. 马尔科夫随机场(Markov Random Field)

    马尔可夫随机场(Markov Random Field),它包含两层意思:一是什么是马尔可夫,二是什么是随机场. 马尔可夫过程可以理解为其当前的状态只与上一刻有关而与以前的是没有关系的.X(t+1)= ...

  3. Dev中控件的js事件代码放在form标签中存在问题

    Dev中控件的js事件代码放在form标签中会获取不到(head标签中有其他js代码,未验证是否是这个问题)

  4. python 3.x 爬虫基础---正则表达式

    python 3.x 爬虫基础 python 3.x 爬虫基础---http headers详解 python 3.x 爬虫基础---Urllib详解 python 3.x 爬虫基础---Requer ...

  5. Flume - 快速入门

    关于Flume,官方定义如下: Apache Flume is a distributed, reliable, and available system for efficiently collec ...

  6. Java基于ssm框架的restful应用开发

    Java基于ssm框架的restful应用开发 好几年都没写过java的应用了,这里记录下使用java ssm框架.jwt如何进行rest应用开发,文中会涉及到全局异常拦截处理.jwt校验.token ...

  7. 十七、curator recipes之DistributedPriorityQueue

    简介 官方文档:http://curator.apache.org/curator-recipes/distributed-priority-queue.html javaDoc:http://cur ...

  8. SQL Server Profiler小技巧——筛选请求

    如果需要转载,请附上本文作者和原文链接:http://www.cnblogs.com/zeusro/p/4016228.html Microsoft SQL Server Profiler 是 SQL ...

  9. cakephp中使用大括号的形式避免用点号连接sql语句

    在cakephp中可以使用{}的形式来代替点号连接sql语句,减少出错的几率

  10. c#中表达式的返回值是啥?

    今天在学javascript的时候发现它其中有一个语法是这样的(a="haha).length;这样也能够输出haha这个字符串的长度,然而我在使用c#的时候分行读取txt文本的时候也用这个 ...