jQuery图片滚动插件
//该组件目前仅适用于一次移动一张图片的情况
(function ($) {
$.fn.extend({
"scroll": function (options) {
options = $.extend({
prevId: 'prevBtn', //左按钮的Id
nextId: 'nextBtn', //右按钮的Id
moveImgCount: '1', //click一次滚动的图片个数
perImgCount: '1', //每个版面显示的图片个数
speed: '800', //滚动一次的时间
prevBtnClass: '', //左按钮样式
nextBtnClass: '', //右按钮样式
highlightLClass: 'img_onbtnL', //左按钮的高亮效果类名
highlightRClass: 'img_onbtnR', //右按钮的高亮效果类名
highlightTag: 'scroll_tag span',
highlightTagClass: 'on',
isAutoPlay: false,
autoPlayTime: 1000
}, options);
var cur = 1; //版面计数
var moveImgCount = options.moveImgCount;
var imglen = parseInt($(this).css("width")) + parseInt($(this).css("margin-right")) + parseInt($(this).css("margin-left")); //一张图片的宽度
var imgWidth = moveImgCount * imglen; //一次滚动多长距离
var speed = options.speed;
var prevId = $("#" + options.prevId);
var nextId = $("#" + options.nextId);
var isAutoPlay = options.isAutoPlay;
var autoPlayTime = options.autoPlayTime;
var imgs = $(this); //取得图片集合
var direction = 1; //1为右,0为左
var scrollPrevId = -1;
var scrollNextId = -1;
if (imgs.length <= options.perImgCount) {
return;
}
//var totalCur = Math.ceil(imgs.length / moveImgCount);
var totalCur = imgs.length - options.perImgCount + 1;
if (isAutoPlay) {
imgs.touchstart(function () {
if (scrollPrevId != -1) {
clearInterval(scrollPrevId);
scrollPrevId = -1;
}
if (scrollNextId != -1) {
clearInterval(scrollNextId);
scrollNextId = -1;
}
});
imgs.touchend(function () {
bind();
});
}
bind(); //执行函数 function scrollPrev() {
direction = 0;
if (cur == 2) { //向前滚到倒二个版面时
if (imgs.length % moveImgCount == 0) { //图片数刚好
imgs.animate({ left: "+=" + imgWidth + "px" }, speed);
} else { //图片数不够
imgs.animate({ left: "+=" + imglen * (imgs.length % moveImgCount) + "px" }, speed);
}
} else {
imgs.animate({ left: "+=" + imgWidth + "px" }, speed); //图片向前滚动
}
cur--; //版面递减
bind();
}
function scrollNext() {
direction = 1;
if (cur == totalCur - 1) { //向后滚到倒二个版面时
if (imgs.length % moveImgCount == 0) { //图片数刚好
imgs.animate({ left: "-=" + imgWidth + "px" }, speed);
} else { //图片数不够
imgs.animate({ left: "-=" + imglen * (imgs.length % moveImgCount) + "px" }, speed);
}
} else {
imgs.animate({ left: "-=" + imgWidth + "px" }, speed); //图片向后滚动
}
cur++; //版面递增
bind();
}
function highlightL() { //左按钮高亮效果
prevId.removeClass(options.prevBtnClass).addClass(options.highlightLClass);
}
function noHighlightL() { //移除左按钮高亮效果
prevId.removeClass(options.highlightLClass).addClass(options.prevBtnClass);
}
function highlightR() { //右按钮高亮效果
nextId.removeClass(options.nextBtnClass).addClass(options.highlightRClass);
}
function noHighlightR() { //移除右按钮高亮效果
nextId.removeClass(options.highlightRClass).addClass(options.nextBtnClass);
}
function bind() {
prevId.unbind("click", scrollPrev); //click事件与swipe事件解绑
nextId.unbind("click", scrollNext);
imgs.unbind("swipeleft", scrollNext);
imgs.unbind("swiperight", scrollPrev);
if (isAutoPlay) {
if (scrollPrevId != -1) {
clearInterval(scrollPrevId);
scrollPrevId = -1;
}
if (scrollNextId != -1) {
clearInterval(scrollNextId);
scrollNextId = -1;
}
}
$("." + options.highlightTag + ":eq(" + (cur - 1) + ")").addClass(options.highlightTagClass).siblings().removeClass(options.highlightTagClass);
if (cur == 1) { //判断是否在第一个版面
nextId.bind("click", scrollNext); //给右按钮绑定click事件
imgs.bind("swipeleft", scrollNext); //触摸屏手指向左移图片向右滚
if (isAutoPlay) {
if (scrollNextId == -1) {
scrollNextId = setInterval(scrollNext, autoPlayTime);
}
}
highlightR(); //右按钮高亮
noHighlightL(); //左按钮移除高亮
} else if (cur == totalCur) { //判断是否在最后一个版面
if (isAutoPlay) {
if (scrollPrevId == -1) {
scrollPrevId = setInterval(scrollPrev, autoPlayTime);
}
}
prevId.bind("click", scrollPrev); //给左按钮绑定click事件
imgs.bind("swiperight", scrollPrev); //触摸屏手指向右移图片向左滚
highlightL(); //左按钮高亮
noHighlightR(); //右按钮移除高亮
} else {
nextId.bind("click", scrollNext); //绑定click事件与swipe事件
prevId.bind("click", scrollPrev);
imgs.bind("swipeleft", scrollNext);
imgs.bind("swiperight", scrollPrev);
if (isAutoPlay) {
if (direction == 0) {
if (scrollPrevId == -1) {
scrollPrevId = setInterval(scrollPrev, autoPlayTime);
}
} else {
if (scrollNextId == -1) {
scrollNextId = setInterval(scrollNext, autoPlayTime);
}
}
}
highlightR(); //右按钮高亮
highlightL(); //左按钮高亮
}
}
}
});
})(jQuery);
jQuery图片滚动插件的更多相关文章
- 【精心推荐】12款很好用的 jQuery 图片滚动插件
这里收集了12款很好用的 jQuery 图片滚动插件分享给大家.jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各 ...
- 10款很好用的 jQuery 图片滚动插件
jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各种很酷的图片效果,它可以让的网站更具吸引力.这里收集了10款很好 ...
- jQuery全能图片滚动插件
插件开发背景 随着前端开发领域越来越受到重视,前端开发也变得越来越火热.各种优秀的前端组件层出不穷.尤其是jQuery插件,很多前端组件都是基于jQuery开开发的. 图片滚动是前端开发中可以说是非常 ...
- 利用jQuery无缝滚动插件liMarquee实现图片(链接)和文字(链接)向右无缝滚动(兼容ie7+)
像新闻类的版块经常要求一条条的新闻滚动出现,要实现这种效果,可以使用jQuery无缝滚动插件liMarquee. 注意: 1. 它的兼容性是IE7+,及现代浏览器. 2. 引用的jquery的版本最好 ...
- 分享22款响应式的 jQuery 图片滑块插件
响应式(Responsive)设计的目标是要让产品界面能够响应用户的行为,根据不同终端设备自动调整尺寸,带给用户良好的使用体验.这篇文章收集了22款优秀的响应式 jQuery 幻灯片插件,它们能够帮助 ...
- 一款超炫的jquery图片播放插件[Cloud Carousel]
今天给大家介绍一个jquery图片播放插件,也可以说是一款幻灯片放映插件,它叫Cloud Carousel,支持自动播放.图片预览.鼠标滚轮滚动,非常酷,下图是效果预览. 该jquery图片播放项目演 ...
- 一款手机端的jQuery图片滑块插件
今天我们要介绍一款比较特别的jQuery图片滑块插件,它不仅在PC浏览器上可以使用,而且更适合在手机端的网页中使用.这款jQuery插件不仅可以定义图片切换的方向,而且可以即时切换图片切换的动画方式, ...
- 十个jQuery图片画廊插件推荐
jQuery的画廊插件可以将分组图像和多媒体资料转成类似Flash的图像或照片.当幻灯片已经成为网站的重要组成部分,jQuery的重要性不能被忽视.下面为你介绍了10个最有美感,创新性和创造性的jQu ...
- jquery图片播放插件Fancybox使用详解
今天给大家介绍的jquery图片播放插件叫Fancybox,相比LightBox来说,Fancybox相对庞大点,配置也更丰富一些,相信你会喜欢的. Fancybox的项目主页地址:http://fa ...
随机推荐
- Android导包导致java.lang.NoClassDefFoundError
摘要: SDK方法总数是不能超过65k的.是否也引入其他的三方库,导致总数超过限制.超出限制会导致部分class找不到,引发java.lang.NoClassDefFoundError.解决方法:近日 ...
- GridView模版列中设置
在GridView模版列中设置如下<asp:TemplateField HeaderText="删除"> <ItemTemplate> ...
- plist文件里边如果最外层是字典的话,读出来是无序的。
如题. 要想使字典有序的话,可以用数组来存放字典,然后读
- MFC注册窗口类以及FindWindow按窗口类名查询
很多玩游戏的人都知道一般游戏客户端程序是不允许双开的,就是说在同一游戏在启动的时候,是无法打开多个窗口.很多其他软件如酷狗播放器等也是这样.如果把打开的窗口最小化,这时重新启动程序,最小化的窗口会被显 ...
- Redis五种数据类型命令介绍(4)
1.string类型命令 设置值:set id 001 获取值:get id 删除键值:del id 验证键是否存在:exists id 显示所有的key:keys * incr .incrby指 ...
- Delphi在创建和使用DLL的时候如果使用到string,请引入ShareMem单元
当使用了长字符串类型的参数.变量时,如string,要引用ShareMem. 虽然Delphi中的string功能很强大,但若是您编写的Dll文件要供其它编程语言调用时,最好使用PChar类型.如果您 ...
- Linux C编程学习之开发工具2---GDB调试器
简介 GDB是一个功能强大的交互式程序调试工具,主要工作在字符界面下. GDB不仅可以用来调试C/C++ 语言编写的程序,还可以用来调试 Pascal.Objective-C,以及Fortran等语言 ...
- php单点登录之模拟淘宝天猫同步登录
说到单点登录大家都很了解,一个站点登录其他域会自动登录. 单点登录SSO(Single Sign On)的方法有很多,比如:p3p.共享session.共享cookice.第三方OAuth认证. 这里 ...
- 【DWR系列03】- DWR主要类详解
img { border: 1px solid black } 一.简介 首先应该了解这个jar包主要的类,了解了类,就了解了DWR.DWR的在线javadoc:http://directwebrem ...
- winform快速开发平台 -> 工作流组件(仿GooFlow)
对于web方向的工作流,一直在用gooflow对于目前我的winform开发平台却没有较好的工作流组件. 针对目前的项目经验告诉我们.一个工作流控件是很必要的. 当然在winform方面的工作流第三 ...