百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>JS教程> JS Zepto 移动端的 jQuery
分享文章到:

JS Zepto 移动端的 jQuery

发布时间:09/01 来源:未知 浏览: 关键词:

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模块需要本人导入

<!--&lt;!&ndash;引入中心模块;包括很多jQuery中常见办法&ndash;&gt;-->
<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[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的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板