支持移动端和PC端的轻量级轮播图插件&&hammer.js教程-阿里云开发者社区

开发者社区> cometwo123> 正文

支持移动端和PC端的轻量级轮播图插件&&hammer.js教程

简介:
+关注继续查看

这里写图片描述

http://www.swiper.com.cn/

下载:http://download.csdn.net/detail/cometwo/9407912

原文地址:http://www.cnblogs.com/iamlilinfeng/p/4239957.html

这里写图片描述
1、 Pan事件:在指定的dom区域内,一个手指放下并移动事件,即触屏中的拖动事件。这个事件在屏触开发中比较常用,如:左拖动、右拖动等,如手要上使用QQ时向右滑动出现功能菜单的效果。该事件还可以分别对以下事件进行监听并处理:

Panstart:拖动开始、Panmove:拖动过程、Panend:拖动结束、Pancancel:拖动取消、Panleft:向左拖动、Panright:向右拖动、Panup:向上拖动、Pandown:向下拖动

2、 Pinch事件:在指定的dom区域内,两个手指(默认为两个手指,多指触控需要单独设置)或多个手指相对(越来越近)移动或相向(越来越远)移动时事件。该事件事以分别对以下事件进行监听并处理:

Pinchstart:多点触控开始、Pinchmove:多点触控过程、Pinchend:多点触控结束、Pinchcancel:多点触控取消、Pinchin:多点触控时两手指距离越来越近、Pinchout:多点触控时两手指距离越来越远

3、 Press事件:在指定的dom区域内触屏版本的点击事件,这个事件相当于PC端的Click事件,该不能包含任何的移动,最小按压时间为500毫秒,常用于我们在手机上用的“复制、粘贴”等功能。该事件分别对以下事件进行监听并处理:

Pressup:点击事件离开时触发

4、 Rotate事件:在指定的dom区域内,当两个手指或更多手指成圆型旋转时触发(就像两个手指拧螺丝一样)。该事件分别对以下事件进行监听并处理:

Rotatestart:旋转开始、Rotatemove:旋转过程、Rotateend:旋转结束、Rotatecancel:旋转取消

5、 Swipe事件:在指定的dom区域内,一个手指快速的在触屏上滑动。即我们平时用到最多的滑动事件。

Swipeleft:向左滑动、Swiperight:向右滑动、Swipeup:向上滑动、Swipedown:向下滑动

6、Tap事件:在指定的dom区域内,一个手指轻拍或点击时触发该事件(类似PC端的click)。该事件最大点击时间为250毫秒,如果超过250毫秒则按Press事件进行处理。

经验分享:写到这个事件的时候有人必然要问了,在触屏中我们使用Click事件不也可以吗?这个Tap事件与Click事件有什么区别呢?博主也曾经有过这样的疑惑,起初在触屏上处理点击的时候也一直用的click事件,并且没也有出现任何问题,直到有一天为一个公司做了微信版本的“连连看”小游戏,连连看的业务简单来说就是屏幕上有很多图片,当点击两个相同图案的图片时可以在中间产生连接线,并且产生爆破效果后消失。这个游戏刚开始做的时候是在ff浏览器上做的测试,鼠标点击后效果非常流畅,但当游戏部署到服务器上并用手机端操作时,iphone和wp都非常流畅,安卓下不管怎么调都是有卡顿。起初以为是手机性能的问题,但换了高配手机后仍然会有卡顿,游戏也不是不能玩,就是反应慢。经过多次的测试后排除了手机配置的硬件原因,开始怀疑click事件。经过网上查阅后才得知,在安卓触屏上,Tap事件和click事件可以同时触发,但click事件会有几百毫秒的延迟,即先触发Tap事件,过一段时间再触发click事件。后来把游戏的所有click事件修改成Tap事件问题就自然解决了。

 <!DOCTYPE html>
<html lang="zh">

    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta content="initial-scale=1.0,maximum-scale=1.0,width=device-width" name="viewport">
        <meta name="apple-touch-fullscreen" content="YES">
        <meta name="format-detection" content="telephone=no">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <meta http-equiv="expires" content="0">
        <meta http-equiv="pragma" content="no-cache">
        <meta http-equiv="cache-control" content="no-cache">
        <title>jQuery支持触摸事件的轮播图</title>
        <link rel="stylesheet" type="text/css" href="css/default.css">
        <link rel="stylesheet" href="css/jquery.hiSlider.min.css">
        <script src="js/jquery.1.9.1.js"></script>
        <script src="js/jquery.hiSlider.min.js"></script>
        <script type="text/javascript" src="js/hammer.js"></script>
        <script>
            $(function() { //首页轮播图
                $('.hiSlider3').hiSlider({
                    isFlexible: true,
                    isSupportTouch: true,
                    titleAttr: function(curIdx) {
                        return $('img', this).attr('alt');
                    }
                });
            });
            $(function() {
                var i = 0;
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test1"));
                //添加事件
                hammertime.on("tap", function(e) {
                    document.getElementById("result1").innerHTML = "点击触发第" + (i++) + "次,长按无效";
                    //控制台输出
                    console.log(e);
                });
            });
            $(function() {
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test2"));
                //添加事件
                hammertime.on("swipeleft", function(e) {
                    document.getElementById("result2").innerHTML = "向左滑动:    X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
                hammertime.on("swiperight", function(e) {
                    document.getElementById("result2").innerHTML = "向右滑动:    X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
                //垂直方向默认是关闭的,swipeup,swipedown默认不能用,需手动打开,可能会影响左右滑动
//              hammertime.get('swipe').set({
//                  direction: Hammer.DIRECTION_VERTICAL
//              });
                hammertime.on("swipeup", function(e) {
                    document.getElementById("result2").innerHTML = "向上滑动:    X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
                hammertime.on("swipedown", function(e) {
                    document.getElementById("result2").innerHTML = "向下滑动:    X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
            });
            $(function() {
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test3"));
                //添加事件
                hammertime.on("pan", function(e) {
                    document.getElementById("result3").innerHTML = "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
            });
            $(function() {
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test4"));
                //为该dom元素指定触屏移动事件
                hammertime.add(new Hammer.Pinch());
                //添加事件
                hammertime.on("pinchin", function(e) {
                    document.getElementById("result4").innerHTML = "两手指越来越近<br />";
                    //控制台输出
                    console.log(e);
                });
                hammertime.on("pinchout", function(e) {
                    document.getElementById("result4").innerHTML = "两手指越来越远<br />";
                    //控制台输出
                    console.log(e);
                });
            });
            $(function() {
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test5"));
                //添加事件
                var i = 0;
                hammertime.on("press", function(e) {
                    document.getElementById("result5").innerHTML = "第" + (i++) + "次按压超过500ms了<br />";
                    //控制台输出
                    console.log(e);
                });
            });
            $(function() {
                //创建一个新的hammer对象并且在初始化时指定要处理的dom元素
                var hammertime = new Hammer(document.getElementById("test6"));
                //为该dom元素指定触屏移动事件
                hammertime.add(new Hammer.Rotate());
                //添加事件
                hammertime.on("rotate", function(e) {
                    document.getElementById("result6").innerHTML = "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />";
                    //控制台输出
                    console.log(e);
                });
            })
        </script>
        <style type="text/css">
            body,
            html,
            * {
                margin: 0;
                padding: 0;
            }

            body {
                width: 100%;
                font: 14px/2 'Microsoft YaHei', 'Arial';
            }

            h2 {
                text-align: center;
                color: red;
            }

            li {
                list-style: none;
            }

            li img {
                display: block;
                margin: 0 auto;
            }

            #main {
                padding: 1px;
                /*min-width: 400px;*/
                margin: 0px;
                background: #fefefe;
            }

            .hiSlider {
                overflow: hidden;
                height: 280px;
                margin: 0px;
                background: #eee;
            }

            .hiSlider-item {
                float: left;
            }
            /*hiSlider.js教程*/

            .test {
                width: 100%;
                height: 150px;
                background: blue;
                text-align: left;
            }

            .result {
                width: 100%;
                height: 150px;
                background: green;
                text-align: left;
                overflow: hidden;
            }
        </style>

    </head>

    <body>
        <div id="main">
            <h2>jQuery支持移动端轮播图</h2>
            <ul class="hiSlider hiSlider3">
                <li class="hiSlider-item"><img src="images/1.jpg" alt="我是第1幅图"></li>
                <li class="hiSlider-item"><img src="images/2.jpg" alt="我是第2幅图"></li>
                <li class="hiSlider-item"><img src="images/3.jpg" alt="我是第3幅图"></li>
                <li class="hiSlider-item"><img src="images/4.jpg" alt="我是第4幅图"></li>
                <li class="hiSlider-item"><img src="images/5.jpg" alt="我是第5幅图"></li>
            </ul>
            <h2>hammer.js教程1:tap事件(点击事件)</h2>
            <div>
                <div id="test1" class="test">事件区域</div>
                <div id="result1" class="result">事件结果</div>
            </div>
            <h2>hammer.js教程2:swipe事件(滑动事件)</h2>
            <div>
                <div id="test2" class="test">事件区域</div>
                <div id="result2" class="result">事件结果</div>
            </div>
            <h2>hammer.js教程3:pan事件(拖动事件)</h2>
            <div>
                <div id="test3" class="test">事件区域</div>
                <div id="result3" class="result">事件结果</div>
            </div>
            <h2>hammer.js教程4:pinch事件(多点触控事件)</h2>
            <div>
                <div id="test4" class="test">事件区域</div>
                <div id="result4" class="result">事件结果</div>
            </div>
            <h2>hammer.js教程5:press事件(按压事件)</h2>
            <div>
                <div id="test5" class="test">事件区域</div>
                <div id="result5" class="result">事件结果</div>
            </div>
            <h2>hammer.js教程6:rotate事件(旋转事件)</h2>
            <div>
                <div id="test6" class="test">事件区域</div>
                <div id="result6" class="result">事件结果</div>
            </div>
        </div>

    </body>

</html>

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
React.js 入门与实战之开发适配PC端及移动端新闻头条平台课程上线了
作者:Parry 出处:http://www.cnblogs.com/parry/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
859 0
vscode插件快餐教程(4) - 语言服务器协议lsp
在有lsp之前,存在三个主要问题: 一是语言相关的扩展都是用该语言母语写的,不容易集成到插件中去。毕竟现在大量的语言都带有运行时。 二是语言扫描相关的工作都比较占用CPU资源,运行在vscode内部不如放在独立进程,甚至远程服务器上更好。
2783 0
第八章 让Bootstrap轮播插件carousel支持左右滑动手势的三种方法
因为最近开发的项目涉及到移动设备上的 HTML5 开发,其中需要实现轮播效果。然后最快捷的方式,你知道的(Bootstrap),然后原生的 Bootstrap 的 carousel.js 插件并没有支持手势。
1060 0
CDH5 Hadoop如何支持读写OSS
CDH和CM(Cloudera Manager) CDH (Cloudera’s Distribution, including Apache Hadoop)是众多Hadoop发行版本中的一种,由Cloudera维护,目前有不少用户使用这个发行版本。
3111 0
《手机测试Robotium实战教程》—第2章2.4节ADT插件的安装
ADT是为了便于在Eclipse下开发Android应用的一款插件。与安装其他Eclipse插件类似,可以在Eclipse Help菜单下选择Install New Software选项,然后输入插件地址进行下载。
1299 0
x3d
[译]Godot系列教程五 - 制作Godot编辑器插件
制作插件 下文仅针对2.1版本。 关于插件 插件是为编辑器扩展出更多有用工具的重要方式。它可以完全用GDScript和标准场景开发,甚至都不需重新加载编辑器就可生效。不像模块,你无需创建C++代码、也无需重新编译整个引擎。
1089 0
+关注
1028
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载