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. 用jeecg做个项目第三讲(自定义导入导出)

    1.导入 前端js和跳转页面 <t:dgToolBar title="导入单一模板" icon="icon-put" funname="Impo ...

  2. WebSphere 安装部署,发布web应用

    转: WebSphere 安装部署,发布web应用 2017年11月20日 23:51:08 greensure 阅读数 20099   版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权 ...

  3. centos7.5配置ntp时间服务器

    Centos7配置ntp时间服务器 Centos7配置时间服务器,一个服务端,多个客户端,客户端去同步服务端 服务端: 1.先修改时区,否则即使配置完ntp时间也不对,修改时区参照:https://w ...

  4. nginx反向代理本地 两台web负载均衡 使用ip+端口代理

    环境: 本地外网ip:123.58.251.166 .配置index.html网页 [root@host---- conf.d]# cat /web/sing/index.html <h1> ...

  5. nginx upstream 容错机制

    熟练掌握Nginx负载均衡的使用对运维人员来说是极其重要的!下面针对Nignx负载均衡upstream容错机制的使用做一梳理性说明: 一.nginx的upstream容错 1)nginx 判断节点失效 ...

  6. ASP.NET关于UEditor简单配置和错误修正

    UEditor配置版本为:ueditor1_3_6-utf8-net,放置目录为:/UEditor 一./UEditor/ueditor.config.js文件需要设置: 1.URL修改为:var U ...

  7. new , delete常见用法和与malloc,free比较

    new/delete是C++的运算符.malloc与free是C++/C语言的标准库函数,new/delete只能在C++中使用,malloc与free在C与C++中都能够使用,它们都可用于申请动态内 ...

  8. 第一次git到GitHub过程

    首先在GitHub上创建一个仓库

  9. mysql 不支持group by的解决方案

    进入mysql命令行 执行如下两句语句 set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_ ...

  10. [转帖]sys.dm_exec_connections (Transact-SQL)

    sys.dm_exec_connections (Transact-SQL) https://docs.microsoft.com/en-us/sql/relational-databases/sys ...