JS Zepto 移动端的 jQuery
Zepto
github地址: https://github.com/madrobby/zepto
官方地址: http://zeptojs.com/
中文版地址: http://www.css88.com/doc/zeptojs_api/
Zepto就是jQuery的移动端版本, 可以看做是一个轻量级的jQuery
留意点
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[0].clientX); console.log("clientY", event.targetTouches[0].clientY); /* clientX 10 clientY 8 pageX 1156 pageY 8 */ // 猎取相关于当前页面内容的间隔 console.log("pageX", event.targetTouches[0].pageX); console.log("pageY", event.targetTouches[0].pageY); });
简便案例: 物块拖拽
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>08-touch事件练习</title> <style> *{ margin: 0; padding: 0; } 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[0].clientX; startY = event.targetTouches[0].clientY; }); // 2.监听手指一动事件 oDiv.addEventListener("touchmove", function (event) { // 记载手指移动之后的位置 moveX = event.targetTouches[0].clientX; moveY = event.targetTouches[0].clientY; // 运算两个位置之间相差的间隔, 相差的间隔就是需要移动的间隔 var offsetX = moveX - startX; var offsetY = moveY- startY; // 让div移动起来 oDiv.style.transform = "translate("+offsetX+"px,"+offsetY+"px)"; }); </script> </body> </html>
zepto中touch事件的点透问题
假如两个元素是重叠的(一个在另一个上面), 并且上面一个监听了touchstart事件, 下面一个监听了click事件,那么假如上面一个元素触发touchstart事件之后消逝了, 那么就会显现点透问题
解决方案: fastclick框架
注: 框架必需在前面调取, 并且所有的元素都被注册了fastclick中的事件, 今后所有的click事件都是fastclick的click事件
zepto中的swipe事件
手指在元素上滑动触发的事件
$("div").swipeLeft(function () { // console.log("左滑动"); $(this).animate({left: "0px"}, 1000); }); $("div").swipeRight(function () { // console.log("右滑动"); $(this).animate({left: "100px"}, 1000); }); $("div").swipeUp(function () { // console.log("上滑动"); $(this).animate({top: "0px"}, 1000); }); $("div").swipeDown(function () { // console.log("下滑动"); $(this).animate({top: "100px"}, 1000);
移动端hover事件
移动端只能使用mouseenter和mouseleave来监听移入和移出
iscroll框架
当我们做移动端侧边栏的时候, 本人实现大概会显现bug也大概比力费事,这时候可以用iscroll框架
github地址: https://github.com/cubiq/iscroll
实现步骤
依照框架的需要搭建一个三层的构造
引入iscroll.js框架
创立一个IScroll对象, 把需要滚动的容器给它
var myScroll = new IScroll('.test', { mouseWheel: true, // 开启鼠标滚动滚动 scrollbars: true // 开启滚动条, 但是容器必需是定位的, 不然滚动条的位置不合错误 }); // 相关常用的回调函数 myScroll.on("beforeScrollStart", function () { console.log("手指触摸, 还没有开端滚动"); }); myScroll.on("scrollStart", function () { console.log("开端滚动"); }); myScroll.on("scrollEnd", function () { console.log("完毕滚动"); });
swiper框架
Swiper是纯javascript打造的滑动特效插件,面向手机、平板电脑等移动终端。
Swiper能实现触屏焦点图、触屏Tab切换、触屏多图切换等常用结果。
Swiper开源、免费、不乱、使用简便、功效强大,是架构移动终端网站的重要选中!
怎样使用:
引入对应的css和js文件
依照框架的需求搭建三层构造
创立一个Swiper对象, 将容器元素传递给它,第二个参数接收一个对象
<div> <ul> <li>slider1</li> <li>slider2</li> <li>slider3</li> </ul> </div> <script> var mySwiper = new Swiper('.test',{ loop: true, autoplay: true, // 假如需要分页器 pagination: { el: '.swiper-pagination', }, // 假如需要前进后退按钮 navigation: { nextEl: '.swiper-button-next', prevEl: '.swiper-button-prev', }, // 假如需要滚动条 scrollbar: { el: '.swiper-scrollbar', },); </script>
引荐教程:《JS教程》
以上就是JS Zepto 移动端的 jQuery的具体内容,更多请关注百分百源码网其它相关文章!