//该组件目前仅适用于一次移动一张图片的情况
(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图片滚动插件的更多相关文章

  1. 【精心推荐】12款很好用的 jQuery 图片滚动插件

    这里收集了12款很好用的 jQuery 图片滚动插件分享给大家.jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各 ...

  2. 10款很好用的 jQuery 图片滚动插件

    jQuery 作为最流行的 JavaScript 框架,使用简单灵活,同时还有许多优秀的插件可供使用.其中最令人印象深刻的应用之一就是各种很酷的图片效果,它可以让的网站更具吸引力.这里收集了10款很好 ...

  3. jQuery全能图片滚动插件

    插件开发背景 随着前端开发领域越来越受到重视,前端开发也变得越来越火热.各种优秀的前端组件层出不穷.尤其是jQuery插件,很多前端组件都是基于jQuery开开发的. 图片滚动是前端开发中可以说是非常 ...

  4. 利用jQuery无缝滚动插件liMarquee实现图片(链接)和文字(链接)向右无缝滚动(兼容ie7+)

    像新闻类的版块经常要求一条条的新闻滚动出现,要实现这种效果,可以使用jQuery无缝滚动插件liMarquee. 注意: 1. 它的兼容性是IE7+,及现代浏览器. 2. 引用的jquery的版本最好 ...

  5. 分享22款响应式的 jQuery 图片滑块插件

    响应式(Responsive)设计的目标是要让产品界面能够响应用户的行为,根据不同终端设备自动调整尺寸,带给用户良好的使用体验.这篇文章收集了22款优秀的响应式 jQuery 幻灯片插件,它们能够帮助 ...

  6. 一款超炫的jquery图片播放插件[Cloud Carousel]

    今天给大家介绍一个jquery图片播放插件,也可以说是一款幻灯片放映插件,它叫Cloud Carousel,支持自动播放.图片预览.鼠标滚轮滚动,非常酷,下图是效果预览. 该jquery图片播放项目演 ...

  7. 一款手机端的jQuery图片滑块插件

    今天我们要介绍一款比较特别的jQuery图片滑块插件,它不仅在PC浏览器上可以使用,而且更适合在手机端的网页中使用.这款jQuery插件不仅可以定义图片切换的方向,而且可以即时切换图片切换的动画方式, ...

  8. 十个jQuery图片画廊插件推荐

    jQuery的画廊插件可以将分组图像和多媒体资料转成类似Flash的图像或照片.当幻灯片已经成为网站的重要组成部分,jQuery的重要性不能被忽视.下面为你介绍了10个最有美感,创新性和创造性的jQu ...

  9. jquery图片播放插件Fancybox使用详解

    今天给大家介绍的jquery图片播放插件叫Fancybox,相比LightBox来说,Fancybox相对庞大点,配置也更丰富一些,相信你会喜欢的. Fancybox的项目主页地址:http://fa ...

随机推荐

  1. 数据库sql语句规则

    sql练习: 创建一个名称为mydb1的数据库. create database mydb1; 查看库 show databases; 创建一个使用utf-8字符集的mydb2数据库. create ...

  2. 【Django】--基础知识

    一 什么是web框架? 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统,简单地说,就是你用别人搭建好的舞台来做表演. Web应 ...

  3. check time period

    /**     * @author etao     * @description check last time selected     * @param timePeriod     * @pa ...

  4. CSS 布局

    近日开发中,总感觉页面布局方面力不从心.以前也曾学过这方面的内容,但是不够系统,因此我打算整理一下. 在web 页面中一般有 table 和 css+div 两种布局方式. 其中css+div 又分为 ...

  5. elasticsearch5.0.0 安装插件及配置过程

    elasticsearch5.0.0 安装插件及配置过程 由于es5.0是里程碑式的更新,所以很多变化的地方,暂时我就插件安装遇到的问题记录一下. 插件安装命令 2.3版本的安装命令 安装Marvel ...

  6. 【React】启动dva脚手架

    开始前: 确保node版本为6.5以上. // 安装脚手架 npm i dva-cli -g // 自动安装新工程 dva new newProjectName // 导入antd包 npm i an ...

  7. webform中Session和Cookie对象的用法

    Session: Session:在计算机中,尤其是在网络应用中,称为"会话控制".Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 Web页之间 ...

  8. [leetcode] 提醒整理之进制

    12. Integer to Roman Given an integer, convert it to a roman numeral. Input is guaranteed to be with ...

  9. 《UML大战需求分析》阅读随笔(六)

    在我们做的代码设计中分为系统设计和程序设计.程序设计是系统设计中模拟程序的执行逻辑,定义客户机服务器对象合作的框架的那个部分.程序和事务设计中,作者讲述到程序和事务设计将系统设计制品放在一起,并作为系 ...

  10. SPOJ DISUBSTR ——后缀数组

    [题目分析] 后缀数组模板题. 由于height数组存在RMQ的性质. 那么对于一个后缀,与前面相同的串总共有h[i]+sa[i]个.然后求和即可. [代码](模板来自Claris,这个板子太漂亮了) ...