实现一个3D图片轮播插件 —— 更新版
前言:
前段时间写下了之前那篇 3D图片轮播效果,后来发现了 Pedro Botelho 写的jquery.gallery.js ,于是重新修改了自己的这个图片轮播,使之可以成为一个插件来使用。
基于jquery.gallery.js 添加了 自适应图片数量,以及添加了 swipe-indicators 切换按钮
源代码:here
demo:here
具体使用:
html结构:
<div id="swipe">
<div class="swipe-wrapper">
<div class="swipe-list">
<a href="#">
<img src="https://y.gtimg.cn/music/common/upload/t_focus_info_iphone/67011.jpg" alt="" class="swipe_list_pic">
</a>
</div>
<ol class='swipe-indicator'>
<li data-index="0"></li>
<li data-index="1"></li>
<!-- .... -->
</ol>
<nav class="swipe-action">
<a href="#" class="prev"><span>«</span></a>
<a href="#" class='next'><span>»</span></a>
</nav>
</div>
</div>
通过javascript使用
$("#swipe").Swipe()
选项 Options:
| Name | Type | Default |
| interval | number | 3000 |
| autoplay | boolean | false |
| current | number | 0 |
初始化方法 :Swipe(options)
使用可选选项初始化轮播,然后开始循环播放项目。
$('#swipe').Swipe({
interval: 2000,
autoplay:true
})
原理分析:
Swipe插件的几个主要私有方法:
_setItems():用于更新图片位置,五个主要元素,按照先后顺序分别为:this.$prevItem,this.$leftItem.this.$currentItem,this.$rightItem.this.$nextItem,顾名思义,大家很容易懂得
// 更新图片位置
_setItems: function () {
this.$items.removeClass('current'); this.$currentItem = this.$items.eq(this.current)
.addClass('current');
this.$leftItem = (this.current === 0) ? this.$items.eq(this.itemsCount -
1) : this.$items.eq(this.current - 1); this.$rightItem = (this.current === this.itemsCount - 1) ? this
.$items
.eq(0) : this.$items.eq(this.current + 1); //next & previous items
if (this.itemsCount > 3) {
// next item
this.$nextItem = (this.$rightItem.index() === this.itemsCount -
1) ?
this.$items.eq(0) : this.$rightItem.next(); // previous item
this.$prevItem = (this.$leftItem.index() === 0) ? this.$items
.eq(
this.itemsCount - 1) : this.$leftItem.prev();
}
},
根据this.current找到这五个元素,其他元素通过 opacity:0; 进行隐藏。
_layout():定义样式
_layout: function () {
// current, left and right items
this._setItems();
// current item is not changed
// left and right one are rotated and translated
this.$leftItem.css(this._getCoordinates('left'));
this.$rightItem.css(this._getCoordinates('right'));
this.$currentItem.css(this._getCoordinates('center'));
this.$nextItem.css(this._getCoordinates('outright'));
this.$prevItem
.css(this._getCoordinates('outleft'));
// 定义indicators样式,当前索引 高亮背景
this.$indicators.eq(this.current)
.css('background', 'rgb(244, 67, 54)')
.siblings()
.css("background", "rgba(0, 0, 0, 0.2)");
},
_getCoordinates(position):接受一个position参数,获取位置值,返回_layout()所需要的样式;【可通过修改此处的样式,自定义自己所需要的轮播效果】
具体看源代码
_loadEvent():初始化绑定各种事件
_slide(dir):接受一个滑动方向,用于图片滑动。根据滑动方向,调整this.current的索引,然后调用this._layout()进行图片位置更新和样式变化
_slide: function (dir) {
if (this.isAnim)
return false;
this.isAnim = true;
this.$items.addClass("swipe-transition");
switch (dir) {
case 'next':
this.current = this.$rightItem.index();
this._layout();
break;
case 'prev':
this.current = this.$leftItem.index();
this._layout();
break;
};
}
_switchItems():主要是用于indicators的切换图片
_cycle(): 定义一个定时器,用于图片循环
_cycle: function () {
var _self = this;
this.$cycle = setTimeout(function () {
_self._slide('next');
if (_self.options.autoplay) {
_self._cycle();
}
}, this.options.interval);
}
利用$.fn实现Swipe方法,看Jquery源码便可知:$.fn=$.prototype
$.fn.Swipe = function (options) {
if (options === undefined) options = {};
if (typeof options === 'object') {
this.each(function () {
// jQuery.data( element, key, value )
var instance = $.data(this, 'Swipe');
if (!instance) {
$.data(this, 'Swipe', new $.Swipe(options, this));
}
});
} else {
this.each(function () {
var instance = $.data(this, 'Swipe');
if (instance) {
switch (options) {
case 'cycle':
instance._cycle();
instance.options.autoplay = true;
break;
case 'stop':
instance._stopCycle();
instance.options.autoplay = false;
break;
case 'next':
instance._slide('next');
break;
case 'prev':
instance._slide('prev');
break;
default:
logError("no such method '" + options +
"' for Swipe instance");
break;
}
} else {
logError(
"cannot call methods on Swipe prior to initialization; " +
"attempted to call method '" + options + "'");
return;
}
});
}
return this;
};
此处给jQuery对象添加了一个Swipe()方法,接受一个可选选项,通过 $("#id").Swipe(); 可声明一个Swipe轮播对象,当Swipe对象初始化成功后,即可通过传入 string类型,调用API
// 可选方法
$("#id").Swipe('cycle')
循环通过旋转木马项目从左到右。 $("#id").Swipe('stop')
停止旋转木马循环播放项目。 $("#id").Swipe('prev')
循环到上一个项目。 $("#id").Swipe('next')
循环到下一个项目。
结束语
刚才在爱脚本网,发现了自己的这篇博文,因此重新附下此句版权声明
版权声明:本文为博主原创文章,未经博主允许不得转载。
实现一个3D图片轮播插件 —— 更新版的更多相关文章
- Javascript和jQuery WordPress 图片轮播插件, 内容滚动插件,前后切换幻灯片形式显示
用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美的图片轮播效果,希望这些插件 ...
- 12款经典的白富美型—jquery图片轮播插件—前端开发必备
图片轮播是网站中的常用功能,用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美 ...
- AdPlayBanner:功能丰富、一键式使用的图片轮播插件
AdPlayBanner:功能丰富.一键式使用的图片轮播插件 AdPlayBanner是一个Android平台基于ViewPager实现的轮播图插件,主要用以自动或者手动地播放轮播图,提供了Fresc ...
- PgwSlideshow-基于Jquery的图片轮播插件
0 PgwSlideshow简介 PgwSlideshow是一款基于Jquery的图片轮播插件,基本布局分为上下结构,上方为大图轮播区域,用户可自定义图片轮播切换的间隔时间,也可以通过单击左右方向按键 ...
- JQuery插件之图片轮播插件–slideBox
来源:http://www.ido321.com/852.html 今天偶然发现了一个比较好用的图片轮播插件—slideBox 先看看效果:http://slidebox.sinaapp.com/ 代 ...
- 结构-行为-样式-requireJs实现图片轮播插件
最近工作需要,就自己写了一个图片轮播插件,不过想到要集成到框架中,于是又用RequireJs改了一遍. 主要文件: style.css jquery-1.11.1.min.js require.js ...
- 面板支持单个,多个元素的jQuery图片轮播插件
一.先附上demo <!doctype html> <html> <head> <meta charset="utf-8"> < ...
- jquery做一个小的轮播插件---有BUG,后续修改
//首页无缝轮播 ; (function($, window, document, undefined) { $.fn.slider = function(options) { var default ...
- Nivo Slider - 世界上最棒的 jQuery 图片轮播插件
Nivo Slider 号称世界上最棒的图片轮播插件,有独立的 jQuery 插件和 WordPress 插件两个版本.目前下载量已经突破 1,800,000 次!jQuery 独立版本的插件主要有如 ...
随机推荐
- vue地址栏发生变化但是页面不会更新怎么办
话不多说直接上问题,主要是在使用router-link进行页面跳转时,使用query进行地址栏传输数据,发现当点击跳转一次之后再次点击虽然地址栏上问号后面的数据会改变,但是页面并不会更新,导致页面永远 ...
- QFramework 使用指南 2020(七):Res Kit (1)概述与基本使用
在上一篇,我们刚刚结束了 脚本生成专题,我们知道 QF 提供了两种脚本生成模式,一种是 ViewController + Bind ,另一种是 UI Kit 模式. 本来打算,介绍完 ViewCont ...
- 安装python的第三方库pillow
参考:http://jingyan.baidu.com/article/ff42efa929e6c8c19f220254.html 用Python做图像处理时,需要用到PIL(图像处理库).但是PIL ...
- [python] - 读取文件内容,并输出
1.读取文件,并逐行输出内容,代码如下: # coding=gbk import os path = 'E:\python_practice' os.chdir(path) fname = raw_i ...
- STL 中priority_queue小结
(1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue> (2)在头文件中priority_queue定义如下: nam ...
- cogs2823求组合数(lucas定理
http://cogs.pro:8080/cogs/problem/problem.php?pid=vNQJJVUVj 再写个数学水题,其实lucas适用于m,n比较大而p比较小的情况. 题意:给出两 ...
- 牛客暑假多校 F RIKKA with Line Graph
题意: 现在有一副完全图, 将他转化成线图. 线图就是 把原来的图上的边都变成点, 然后如果原来的任意2条边存在公共点, 他们就会有一条边, 边权为原来的2条边的和. 最后求出线图中的任意2点的最短路 ...
- Cookie与Seesion的作用
1.什么是Cookie与Session? cookie:首次访问服务器,服务器返回cookie置浏览器,存到用户电脑.之后去访问同一服务器,浏览器会携带相应cookie判断是否是同一浏览器的访问,告知 ...
- length属性、length()方法和size()的方法的区别
JAVA 1. length属性是针对Java中的数组来说的,要求数组的长度可以用其length属性: 2.length()方法是针对字符串来说的,要求一个字符串的长度就要用到它的length()方法 ...
- 前端-HTML-web服务本质-HTTP协议-请求-标签-01(待完善)
目录 前端 什么是前端 什么是后端 学习流程 前端三剑客的形容 web服务的本质 测试--浏览器作为客户端向服务器发起请求 浏览器输入网址回车发生了几件事 ***** HTTP协议(超文本传输协议) ...