zepto

Zepto就是jQuery的移动端版本, 可以看做是一个轻量级的jQuery

注意点:

  • Zepto的设计目的是提供 jQuery 类似的API,但并不是100%覆盖 jQuery

  • jQuery的底层是通过DOM来实现效果的, zepto.js 是用css3 来实现的;

  • 官网下载的zepto,就已经包含了官网所述的默认模块了

  • github上下载的zepto模块需要自己导入

// <!–引入核心模块;包含许多jQuery中常见方法–>
<script src="js/zepto.js"></script>
//&lt;!&ndash;引入zepto事件模块, 包含了常见的事件方法on/off/click ...&ndash;&gt;
<script src="js/event.js"></script>
// &lt;!&ndash;引入zepto动画模块,&ndash;&gt;
<script src="js/fx.js"></script>
// &lt;!&ndash;引入zepto动画模块的常用方法,&ndash;&gt;
<script src="js/fx_methods.js"></script>

zepto点击事件

由于移动端的手势多而且分单击双击,所以移动端的click事件有300ms左右的延迟,所以移动端的点击事件用tab

$("div").tap(function(){

        ......

})

zepto中touch相关事件

touchstart:touchstart是手指刚触摸到元素时触发的事件

touchmove:touchmove是手指移动时触发的事件

touchend:当手指离开指定元素时触发

注意:

  • 添加以上三个事件的时候用addEventListener

  • 以上三个事件对pc端无效

zepto中touch事件的对象

touches:保存了屏幕上所有手指的列表

targetTouches:保存了元素上所有手指的列表

changedTouches:包含了刚刚与屏幕接触的手指或者刚刚离开屏幕的手指

TouchEvent {

  isTrusted: true,

  touches: TouchList,

  targetTouches: TouchList,

  changedTouches: TouchList

}

zepto中touch事件的XY

  • client: 可视区域

  • page: 内容

 var oDiv = document.querySelector("div");
/*
1.注意点:
无论是event对象中的touches/targetTouches/changedTouches都是一个伪数组
所以我们想要获取手指位置的时候, 需要从伪数组中取出需要获取的那个手指对象
*/
oDiv.addEventListener("touchstart", function (event) {
// 获取手指距离屏幕左上角的位置
// console.log(event.targetTouches[0].screenX);
// console.log(event.targetTouches[0].screenY); // 获取相对于当前视口的距离
console.log("clientX", event.targetTouches[].clientX);
console.log("clientY", event.targetTouches[].clientY); /*
clientX 10
clientY 8
pageX 1156
pageY 8
*/
// 获取相对于当前页面内容的距离
console.log("pageX", event.targetTouches[].pageX);
console.log("pageY", event.targetTouches[].pageY);
});

简单案例: 物块拖拽

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>-touch事件练习</title>
<style>
*{
margin: ;
padding: ;
}
div{
width: 100px;
height: 100px;
background: red;
}
</style>
</head>
<body>
<div></div>
<script>
var oDiv = document.querySelector("div");
var startX, startY, moveX, moveY;
// 1.监听手指按下事件
oDiv.addEventListener("touchstart", function (event) {
// 记录手指按下的位置
startX = event.targetTouches[].clientX;
startY = event.targetTouches[].clientY;
});
// 2.监听手指一动事件
oDiv.addEventListener("touchmove", function (event) {
// 记录手指移动之后的位置
moveX = event.targetTouches[].clientX;
moveY = event.targetTouches[].clientY;
// 计算两个位置之间相差的距离, 相差的距离就是需要移动的距离
var offsetX = moveX - startX;
var offsetY = moveY- startY;
// 让div移动起来
oDiv.style.transform = "translate("+offsetX+"px,"+offsetY+"px)";
});
</script>
</body>
</html>

zepto中touch事件的点透问题

参考:zepto学习(二)之tap事件以及tap事件点透处理

zepto中的swipe事件

手指在元素上滑动触发的事件

    $("div").swipeLeft(function () {
// console.log("左滑动");
$(this).animate({left: "0px"}, );
});
$("div").swipeRight(function () {
// console.log("右滑动");
$(this).animate({left: "100px"}, );
});
$("div").swipeUp(function () {
// console.log("上滑动");
$(this).animate({top: "0px"}, );
});
$("div").swipeDown(function () {
// console.log("下滑动");
$(this).animate({top: "100px"}, );

移动端hover事件

移动端只能使用mouseenter和mouseleave来监听移入和移出

参考

zepto学习(三)之详解的更多相关文章

  1. Struts2框架学习(三)——配置详解

    一.struts.xml配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts ...

  2. MYSQL学习(三) --索引详解

    创建高性能索引 (一)索引简介 索引的定义 索引,在数据结构的查找那部分知识中有专门的定义.就是把关键字和它对应的记录关联起来的过程.索引由若干个索引项组成.每个索引项至少包含两部分内容.关键字和关键 ...

  3. Hibernate学习三----------session详解

    © 版权声明:本文为博主原创文章,转载请注明出处 如何获取session对象 1. openSession 2. getCurrentSession - 如果使用getCurrentSession需要 ...

  4. [转]iOS学习之UINavigationController详解与使用(三)ToolBar

    转载地址:http://blog.csdn.net/totogo2010/article/details/7682641 iOS学习之UINavigationController详解与使用(二)页面切 ...

  5. iOS学习之UINavigationController详解与使用(三)ToolBar

    1.显示Toolbar  在RootViewController.m的- (void)viewDidLoad方法中添加代码,这样Toobar就显示出来了. [cpp] view plaincopy [ ...

  6. iOS学习之UINavigationController详解与使用(一)添加UIBarButtonItem

    http://blog.csdn.net/totogo2010/article/details/7681879 1.UINavigationController导航控制器如何使用 UINavigati ...

  7. 各大公司广泛使用的在线学习算法FTRL详解

    各大公司广泛使用的在线学习算法FTRL详解 现在做在线学习和CTR常常会用到逻辑回归( Logistic Regression),而传统的批量(batch)算法无法有效地处理超大规模的数据集和在线数据 ...

  8. 跟我学机器视觉-HALCON学习例程中文详解-QQ摄像头读取条码

    跟我学机器视觉-HALCON学习例程中文详解-QQ摄像头读取条码 第一步:插入QQ摄像头,安装好驱动(有的可能免驱动) 第二步:打开HDevelop,点击助手-打开新的Image Acquisitio ...

  9. Asp.Net MVC3 简单入门第一季(三)详解Controller之Filter

    前言 前面两篇写的比较简单,刚开始写这个系列的时候我面向的对象是刚开始接触Asp.Net MVC的朋友,所以写的尽量简单.所以写的没多少技术含量.把这些技术总结出来,然后一简单的方式让更多的人很好的接 ...

  10. 从51跳cortex-m0学习2——程序详解

    跳cortex-m0——思想转变>之后又一入门级文章,在此不敢请老鸟们过目.不过要是老鸟们低头瞅了一眼,发现错误,还请教育之,那更是感激不尽.与Cortex在某些操作方式上的异同,让自己对Cor ...

随机推荐

  1. 验证HashSet和HashMap不是线程安全

    JAVA集合类: java.util包下的HashSet和HashMap类不是线程安全的, java.util.concurrent包下的ConcurrentHashMap类是线程安全的. 写2个测试 ...

  2. python爬虫简单实现,并在java中调用python脚本,将数据保存在json文件中

    # coding:utf-8 import urllib2 from bs4 import BeautifulSoup import json import sys reload(sys) sys.s ...

  3. 05-06 Flutter JSON和序列化反序列化、创建模型类转换Json数据、轮播图数据渲染:Flutter创建商品数据模型 、请求Api接口渲染热门商品 推荐商品

    Config.dart class Config{ static String domain='http://jd.itying.com/'; } FocusModel.dart class Focu ...

  4. app怎么获取package与active name

    1.aapt dump badging apk名称 2.adb logcat | grep START 或者 adb shell "logcat | grep START" 然后在 ...

  5. mysql物理备份innobackupex

    一.全量备份 1.安装xtrabackup # wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.4/b ...

  6. MYSQL的MYSQLDUMP命令

    1.用mysqldump对MySQL数据库进行数据备份与恢复 下面假设要备份tm这个数据库:Shell>mysqldump -uroot –p123456 tm > tm_050519.s ...

  7. iOS-AVFoundation实现二维码(ios7以上,转载)

    关于二维码扫描有不少优秀第三方库: ZBar SDK 里面有详细的文档,相应介绍也非常多,如:http://rdcworld-iphone.blogspot.in/2013/03/how-to-use ...

  8. python 智能玩别踩白块

    # encoding :utf-8import pyautoguifrom PIL import Imageimport time pyautogui.FAILSAFE = True time.sle ...

  9. Want To Become A Web Design Expert? Read This Piece

    Want To Become A Web Design Expert? Read This Piece It can be very expensive to hire a web design fi ...

  10. 【计算机视觉】Opencv中的Face Detection using Haar Cascades

    [计算机视觉]Opencv中的Face Detection using Haar Cascades 标签(空格分隔): [图像处理] 声明:引用请注明出处http://blog.csdn.net/lg ...