移动端图片轮播—swipe滑动插件
swipe是一个轻量级的移动滑动组件,它可以支持精确的触滑移动操作,能解决移动端对滑动的需求。
swipe插件的使用主要有四大块:
一、html
- <div id='slider' class='swipe'>
- <div class='swipe-wrap'>
- <div>1</div>
- <div>2</div>
- <div>3</div>
- </div>
- </div>
1.最外层的div的id是自定义的,这个是需要传入到swipe中的
2.最外层div的class="swipe"和第二层div的class="swipe-wrap"是写死的,swipe会查找这两个样式然后做相应的处理
3.第三层的div,是滑动元素的单元。第三层div里可加内容,都是以第三层div为单元进行滑动的
二、css
- .swipe {
- overflow: hidden;
- visibility: hidden;
- position: relative;
- }
- .swipe-wrap {
- overflow: hidden;
- position: relative;
- }
- .swipe-wrap > div {
- float:left;
- width:100%;
- position: relative;
- }
1.swipe、swipe-wrap、swipe-wrap > div,这3个是swipe里的样式是必须要用的
2.除此以外,可以对swipe-wrap > div设置一些其他样式,如居中、长、宽等
三、js
- var mySwipe = new Swipe(document.getElementById('slider'), {
- startSlide: 4, //起始图片切换的索引位置
- auto: 3000, //设置自动切换时间,单位毫秒
- continuous: true, //无限循环的图片切换效果
- disableScroll: true, //阻止由于触摸而滚动屏幕
- stopPropagation: false, //停止滑动事件
- callback: function(index, element) {}, //回调函数,切换时触发
- transitionEnd: function(index, element) {} //回调函数,切换结束调用该函数
- });
四、API(可选)
- prev() //上一页
- next() //下一页
- getPos() //获取当前页的索引
- getNumSlides() //获取所有项的个数
- slide(index, duration) //滑动方法
API使用方法:
- <button onclick="Swipe.prev()">prev</button>
- <button onclick="Swipe.next()">next</button>
五、优缺点
1.优点:滑动与防滑性能不错,用户体验较好;Html结构简单,自定义较灵活
2.缺点:div的高度取决于切换内容最大高度,如果某个单元div无内容,那么会出现一个空白区域;
初始化后,第一、二、三层的div宽度固定;
dom结构固定,初始化后,插件对dom绑定事件,无法在js中增加滑动的dom结构;
滑动后才会触发swipe插件的callback和transitionEnd函数。
六、demo
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title></title>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no">
- <meta name="format-detection" content="telephone=no">
- <script src="/zepto.js"></script>
- <script src="/swipe.js"></script>
- <style>
- .swipe {
- overflow: hidden;
- visibility: hidden;
- position: relative;
- }
- .swipe-wrap {
- overflow: hidden;
- position: relative;
- }
- .wrap-slide {
- float:left;
- width:100%;
- position: relative;
- display: -webkit-box; /*移动端图片居中显示*/
- -webkit-box-orient: horizontal;
- -webkit-box-pack: center;
- overflow: hidden; /*图片过大时,溢出div宽的隐藏,以免影响其他图片的滑动*/
- }
- .slide-img {
- height: 300px; /*固定图片高*/
- }
- .loading {
- position: absolute;
- top: 120px;
- left: 150px;
- }
- .mod-load{
- text-align: center;
- padding: 15px 0;
- color: @fontColor4;
- font-size: 12px;
- }
- @-webkit-keyframes loading{
- 0%{-webkit-transform: rotate(0deg);}
- 50%{-webkit-transform: rotate(180deg);}
- 100%{-webkit-transform: rotate(360deg);}
- }
- .icon-loading{
- display: inline-block;
- width: 15px;
- height: 15px;
- vertical-align: -4px;
- margin-right: 6px;
- transform-style: preserve-3d;
- -webkit-backface-visibility: hidden;
- -webkit-animation-name: loading;
- -webkit-animation-duration: 1.2s;
- -webkit-animation-timing-function: linear;
- -webkit-animation-iteration-count: infinite;
- -moz-animation-name: loading;
- -moz-animation-duration: 1.2s;
- -moz-animation-timing-function: linear;
- -moz-animation-iteration-count: infinite;
- }
- .detail {
- display: -webkit-box;
- -webkit-box-orient: horizontal;
- -webkit-box-pack: justify;
- box-sizing: border-box;
- width: 100%;
- }
- .info {
- -webkit-box-flex: 1;
- }
- .title {
- display: -webkit-box;
- -webkit-box-orient: vertical;
- word-break: break-all;
- overflow: hidden;
- -webkit-line-clamp: 1;
- line-clamp: 1;
- }
- .desc {
- display: -webkit-box;
- -webkit-box-orient: vertical;
- word-break: break-all;
- overflow: hidden;
- -webkit-line-clamp: 3;
- line-clamp: 3;
- }
- .num {
- border-left: 1px solid #000;
- padding-left: 5px;
- max-width: 18%;
- text-align: center;
- }
- </style>
- </head>
- <body>
- <div id='slider' class='swipe'>
- <div class='swipe-wrap'>
- <div class="wrap-slide">
- <img class='slide-img' data-src="http://tgi1.jia.com/115/551/15551390.jpg"></img>
- </div>
- <div class="wrap-slide">
- <img class='slide-img' data-src="http://tgi1.jia.com/115/551/15551440.jpg"></img>
- </div>
- <div class="wrap-slide">
- <img class='slide-img' data-src="http://tgi13.jia.com/115/551/15551388.jpg"></img>
- </div>
- </div>
- </div>
- <div class='detail'>
- <div class='info'>
- <div class='title'></div>
- <div class='desc'></div>
- </div>
- <div class='num'></div>
- </div>
- <script>
- var $img=$('.slide-img');
- var $slide=$('.wrap-slide');
- var $detail=$('.detail');
- var $title=$('.title');
- var $desc=$('.desc');
- var $num=$('.num');
- var windowHeight = $(window).height();
- var pos=0;
- var imgSrc=$img[pos];
- var src;
- var imgLoad;
- var imgHeight;
- var posHeight;
- var detailHeight;
- loading();
- lazyLoad(pos);
- var mySwipe = new Swipe(document.getElementById('slider'), {
- startSlide: 0,
- speed: 400,
- continuous: false,
- disableScroll: false,
- stopPropagation: false,
- callback: function(index, elem) {
- pos = index;
- imgSrc = $img[pos];
- if (imgSrc.hasAttribute('data-src')) {
- loading();
- lazyLoad(pos);
- }else {
- description(pos)
- }
- },
- transitionEnd: function(index, elem) {}
- });
- //加载中...
- function loading(){
- var loadingHtml = '<div class="loading">'
- + '<div class="mod-load list-loading">'
- + '<img class="icon-loading" src="/loading.png">'
- + '加载中...'
- + '</div></div>';
- $(loadingHtml).appendTo($slide);
- }
- //图片延迟加载
- function lazyLoad(pos){
- src = $(imgSrc).attr('data-src');
- $(imgSrc).attr('src',src).removeAttr('data-src');
- imgLoad =document.querySelectorAll(".slide-img")[pos];
- imgLoad.addEventListener("load",function(event){
- $('.loading').remove();
- description(pos);
- });
- }
- //图片描述
- function description(pos){
- $title.html('我是标题我是标题我是标题我是标题'+pos);
- $desc.html('我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容我是内容'+pos);
- $num.html(pos);
- imgHeight= $img[pos].height;
- detailHeight = $detail.height();
- posHeight =imgHeight;
- if(posHeight + detailHeight > windowHeight) {
- $detail.css({
- 'top':windowHeight - detailHeight + 'px',
- });
- }else {
- $detail.css({
- 'top':posHeight+'px',
- });
- }
- }
- </script>
- </body>
- </html>
图0正常显示;图1的图片宽度大于屏幕宽,居中显示,溢出隐藏;图2图片宽度小于屏幕宽度,居中显示。
移动端图片轮播—swipe滑动插件的更多相关文章
- Omi-touch实战 移动端图片轮播组件的封装
pc端的轮播,移动端的轮播都很常见.一年前,我还为手机端没有左滑,右滑事件从而封装了一个swipe库,可以自定义超过多少滑动时间就不触发,也可以设置滑动多少距离才触发,这一个功能的代码就达到400多行 ...
- 移动端图片轮播效果:depth模式总结
最近公司app改版首页增加了一处轮播图效果,但是跟普通的轮播效果不同,是类似于下图的样式,找了一些兼容移动端的插件以及jQuery源码,总结一下使用心得: 1:jquery源码:缺点是在手机端的滑动很 ...
- 让boostrap的图片轮播支持滑动效果
因为最近开发的项目涉及到移动设备上的 HTML5 开发,其中需要实现轮播效果. 然后最快捷的方式,你知道的(Bootstrap),然后原生的 Bootstrap 的 carousel.js 插件并没有 ...
- 图片轮播器——jquery插件
下载:http://files.cnblogs.com/files/wordblog/jiaoben828.rar
- jquery图片轮播插件slideBox
效果预览: 源代码下载: jQuery图片轮播(焦点图)插件jquery.slideBox 特点:兼容IE6+,Chrome,Firefox,Opera,safari,可左右,可上下,可快可慢,可指定 ...
- JQuery slidebox实现图片轮播
jQuery图片轮播(焦点图)插件jquery.slideBox,简单设置下参数就可以多个多种动画效果,左右,上下,速度,还可指定默认显示第N张,点击的按钮在现代浏览中可以实现圆形或圆角效果,插件代码 ...
- PgwSlideshow-基于Jquery的图片轮播插件
0 PgwSlideshow简介 PgwSlideshow是一款基于Jquery的图片轮播插件,基本布局分为上下结构,上方为大图轮播区域,用户可自定义图片轮播切换的间隔时间,也可以通过单击左右方向按键 ...
- 非常优秀的swiper插件————幻灯片播放、图片轮播
http://www.idangero.us/ http://www.swiper.com.cn/ Swiper中文网 2015-10-15 SuperSlide2: (这是个PC用的滚屏插件,看着不 ...
- 实现一个3D图片轮播插件 —— 更新版
前言: 前段时间写下了之前那篇 3D图片轮播效果,后来发现了 Pedro Botelho 写的jquery.gallery.js ,于是重新修改了自己的这个图片轮播,使之可以成为一个插件来使用 ...
随机推荐
- NO.2:自学tensorflow之路------BP神经网络编程
引言 在上一篇博客中,介绍了各种Python的第三方库的安装,本周将要使用Tensorflow完成第一个神经网络,BP神经网络的编写.由于之前已经介绍过了BP神经网络的内部结构,本文将直接介绍Tens ...
- Java 内存模型_1
title: Java 内存模型_1 date: 2017-01-15 17:11:02 tags: [JMM] categories: [Programming,Java] --- 概述 本文记录 ...
- eject命令详解
基础命令学习目录首页 原文链接:http://www.kgc.cn/bbs/post/128680.shtml Linux eject命令用于退出抽取式设备. 若设备已挂入,则eject会先将该设备卸 ...
- 详解HTTP缓存
HTTP缓存是个大公司面试几乎必考的问题,写篇随笔说一下HTTP缓存. 1. HTTP报文首部中有关缓存的字段 在HTTP报文中,与缓存相关的信息都存在首部里,简单说一下首部. 首部 HTTP首部字段 ...
- 欢迎来怼--第二十九次Scrum会议
一.小组信息 队名:欢迎来怼 小组成员 队长:田继平 成员:李圆圆,葛美义,王伟东,姜珊,邵朔,阚博文 小组照片 二.开会信息 时间:2017/11/17 15:55~16:25,总计30min. 地 ...
- (第十周)新NABCD
项目名:食物链教学工具 组名:奋斗吧兄弟 组长:黄兴 组员:李俞寰.杜桥.栾骄阳.王东涵 新的NABCD模型: Need:可以辅助教师课堂讲授食物链相关的知识.软件的界面要漂亮,操作要简单,要给出软件 ...
- No.1000_第五次团队会议
光辉的一夜 今夜注定是不平凡的一夜.是崔强同学伟大的一夜. 昨天因为实验室项目,我刚上完编译课就被学院叫走去做项目,当时我就很无奈,因为说好了要和崔强一起实现下午的前端,他写界面我写底层逻辑,这样我们 ...
- java实验1实验报告(20135232王玥)
实验一 Java开发环境的熟悉 一.实验内容 1. 使用JDK编译.运行简单的Java程序 2.使用Eclipse 编辑.编译.运行.调试Java程序 二.实验要求 1.没有Linux基础的同学建议先 ...
- Servlet以流的形式返回图片
代码: import java.awt.image.BufferedImage; import java.io.File; import java.io.FileInputStream; import ...
- Leetcode题库——35.搜索插入位置
@author: ZZQ @software: PyCharm @file: searchInsert.py @time: 2018/11/07 19:20 要求:给定一个排序数组和一个目标值,在数组 ...