zepto学习(三)之详解
zepto
Zepto就是jQuery的移动端版本, 可以看做是一个轻量级的jQuery
github地址: https://github.com/madrobby/zepto
官方地址: http://zeptojs.com/
注意点:
Zepto的设计目的是提供 jQuery 类似的API,但并不是100%覆盖 jQuery
jQuery的底层是通过DOM来实现效果的, zepto.js 是用css3 来实现的;
官网下载的zepto,就已经包含了官网所述的默认模块了
github上下载的zepto模块需要自己导入
// <!–引入核心模块;包含许多jQuery中常见方法–>
<script src="js/zepto.js"></script>
//<!–引入zepto事件模块, 包含了常见的事件方法on/off/click ...–>
<script src="js/event.js"></script>
// <!–引入zepto动画模块,–>
<script src="js/fx.js"></script>
// <!–引入zepto动画模块的常用方法,–>
<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学习(三)之详解的更多相关文章
- Struts2框架学习(三)——配置详解
一.struts.xml配置 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts ...
- MYSQL学习(三) --索引详解
创建高性能索引 (一)索引简介 索引的定义 索引,在数据结构的查找那部分知识中有专门的定义.就是把关键字和它对应的记录关联起来的过程.索引由若干个索引项组成.每个索引项至少包含两部分内容.关键字和关键 ...
- Hibernate学习三----------session详解
© 版权声明:本文为博主原创文章,转载请注明出处 如何获取session对象 1. openSession 2. getCurrentSession - 如果使用getCurrentSession需要 ...
- [转]iOS学习之UINavigationController详解与使用(三)ToolBar
转载地址:http://blog.csdn.net/totogo2010/article/details/7682641 iOS学习之UINavigationController详解与使用(二)页面切 ...
- iOS学习之UINavigationController详解与使用(三)ToolBar
1.显示Toolbar 在RootViewController.m的- (void)viewDidLoad方法中添加代码,这样Toobar就显示出来了. [cpp] view plaincopy [ ...
- iOS学习之UINavigationController详解与使用(一)添加UIBarButtonItem
http://blog.csdn.net/totogo2010/article/details/7681879 1.UINavigationController导航控制器如何使用 UINavigati ...
- 各大公司广泛使用的在线学习算法FTRL详解
各大公司广泛使用的在线学习算法FTRL详解 现在做在线学习和CTR常常会用到逻辑回归( Logistic Regression),而传统的批量(batch)算法无法有效地处理超大规模的数据集和在线数据 ...
- 跟我学机器视觉-HALCON学习例程中文详解-QQ摄像头读取条码
跟我学机器视觉-HALCON学习例程中文详解-QQ摄像头读取条码 第一步:插入QQ摄像头,安装好驱动(有的可能免驱动) 第二步:打开HDevelop,点击助手-打开新的Image Acquisitio ...
- Asp.Net MVC3 简单入门第一季(三)详解Controller之Filter
前言 前面两篇写的比较简单,刚开始写这个系列的时候我面向的对象是刚开始接触Asp.Net MVC的朋友,所以写的尽量简单.所以写的没多少技术含量.把这些技术总结出来,然后一简单的方式让更多的人很好的接 ...
- 从51跳cortex-m0学习2——程序详解
跳cortex-m0——思想转变>之后又一入门级文章,在此不敢请老鸟们过目.不过要是老鸟们低头瞅了一眼,发现错误,还请教育之,那更是感激不尽.与Cortex在某些操作方式上的异同,让自己对Cor ...
随机推荐
- Linux嵌入式学习过程(转载)
嵌入式专业是一门实践性非常强的学科,只有多动手,多实践,多编程,多调试,多看书,多思考才能真正掌握好嵌入式开发技术.那么,如何从零开始学习嵌入式开发技术, 进入嵌入式开发大门呢,笔者根据自己的嵌入式学 ...
- SQL-W3School-基础:SQL DISTINCT 语句
ylbtech-SQL-W3School-基础:SQL DISTINCT 语句 1.返回顶部 1. 本章讲解 SELECT DISTINCT 语句. SQL SELECT DISTINCT 语句 在表 ...
- [工具]tcping检查开放的端口
tcping小工具是一款用于tcp监控的软件.tcping小工具可以时刻监控服务器的网络情况,包括ping值和端口状态,可以突破机房和服务器的禁用设置,是一款十分实用的网络分析小工具. 下载地址:ht ...
- Java 代码快速注释 和 取消注释
注释掉代码: 把要注释的代码选中: 加/* */ 形式的注释 -> Ctrl+Shift+/ 加 //形式的形式的注释 -> ctrl+/ 取消代码注释: 把要取消注释的代码选中: ...
- ASP.NET关于UEditor简单配置和错误修正
UEditor配置版本为:ueditor1_3_6-utf8-net,放置目录为:/UEditor 一./UEditor/ueditor.config.js文件需要设置: 1.URL修改为:var U ...
- shell学习笔记1-文件安全与权限
1,创建文件的用户和他所属的组拥有该文件,文件的属主可以设定谁具有读.写.执行该文件的权限,根用户可以改变任何普通用户的设置. 2,一个文件一经创建,就具有三种访问权限:读(可以显示该文件的内容).写 ...
- logstash数据迁移
logstash是一个非常强大的数据迁移工具.这里主要记录今天使用到的几个简单用法. 其中比较需要注意的是 迁移到elasticsearch的时候,output 的 elasticsearch 中的 ...
- OpenCV3编程入门.知识点
1. 第三部分 掌握 imgproc 组件 第六章 图像处理 6.1.线性滤波: Pdf.P170 Pdf.P171 平滑处理(smoothing)(模糊处理(bluring))-- 使用频率很高 - ...
- du 和 df命令
测试环境数据库收到磁盘报警时,需要清理部分磁盘空间 df -h 查看整个磁盘占有 找到对应目录 查看每个文件夹占有磁盘量: sudo du -h --max-depth=1 data/ --max-d ...
- 初识gRPC
一.gRPC的概念 gRPC是Google推出的一个开源高性能的轻量级RPC框架,可以在任何环境中运行.它可以有效地连接数据中心内和跨数据中心的服务,并提供可插拔的支持,以实现负载平衡,跟踪,健康检查 ...