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. dd 命令

    dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512:c=1:k=1024:w=2 参数注释: if=文件名:输入文件名 ...

  2. /proc/sys/net/ipv4/ip_conntrack_max

    Things to know (best practices and “issues”) READ IT !!! — uWSGI 2.0 documentationhttps://uwsgi-docs ...

  3. Qt编写数据可视化大屏界面电子看板6-窗体打开关闭

    一.前言 二级窗体的打开与关闭,这个功能也很有必要,由于整个系统中各种模块数量窗体数量比较多,后期可能还会增加更多,在4K屏幕上可以显示很多的模块,但是有时候有些模块不想显示出来,就需要将该模块关闭掉 ...

  4. 使用VLC发送TS流与播放TS流

    使用VLC发送TS流与播放TS流 一.如何使用VLC发送TS流 1.添加一个文件至VLC 2.选择串流,继续 3.选择UDP,点击添加 4.输入地址及端口 5.选择h.264+mp3(TS) 6.ne ...

  5. 修改Eclipse启动时的选择工作空间

    对于eclipse的默认的工作空间,如果不需要正常切换workspace的用户很方便,打开eclipse便自动进入默认的工作空间.而如果用户经常在多个workspace之间切换的话,启动eclipse ...

  6. PAT 甲级 1016 Phone Bills (25 分) (结构体排序,模拟题,巧妙算时间,坑点太多,debug了好久)

    1016 Phone Bills (25 分)   A long-distance telephone company charges its customers by the following r ...

  7. 20190615 NACE关于采购订单的输出类型

    项目已经做好的配置,我们复盘一下 一.使用NACE 进入输出控制条件: EF 采购订单,首先看->输出类型 标准是使用 nast 作为记录表 1输出类型, 2过程, 3 存取顺序,4 条件记录: ...

  8. PowerDesigner常用命令

    在Tools=>Execute Commands下的Edit/Run Scripts,或者通过Ctrl+Shift+X就可以运行脚本.如图: 1.将所有的表名和列名都修改为大写 '******* ...

  9. js模块化编程之彻底弄懂CommonJS和AMD/CMD

    转自 http://www.cnblogs.com/chenguangliang/p/5856701.html

  10. 差分约束算法————洛谷P4878 [USACO05DEC] 布局

    题目: 不难看出题意主要是给出ml+md个格式为xi-xj<=ak的不等式,xi-xj为i,j俩头牛的距离,要我们求x1-xn的最大值. 经过上下加减我们可以将这几个不等式化成x1-xn< ...