jQ版大图滚动
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>jQ版大图滚动</title>
<style>
*{margin: 0; padding: 0; list-style: none; -webkit-user-select: none;}
/*-webkit-user-select: none;取消频繁点击下,文字和图片选中态,每个浏览器有不同的写法,这里只举例了谷歌*/
.btn_mod,.img_mod{width: 400px; margin: 20px auto 0; overflow: hidden;}
.img_mod,.img_mod img{height: 400px;}
.img_mod{position: relative;}
.img_mod .scroll{position: absolute; left: 0; top: 0;}
.img_mod .scroll img{float: left; width: 400px; height: 400px;}
.btn_mod{padding-left: 10px;}
.btn_mod li,.btn_mod div{float: left; width: 60px; height: 30px; line-height: 30px; text-align: center; color: #666; background: #ccc; cursor: pointer; font-size: 14px; margin-right: 6px;}
.btn_mod .active{background: #999;}
</style>
</head>
<body>
<div class="btn_mod">
<div class="prev">上一页</div>
<ul class="btn_list">
<li class="active">1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
<div class="next">下一页</div>
</div>
<div class="img_mod">
<div class="scroll" style="width: 9999px;">
<img src="img/img01.jpg"/>
<img src="img/img02.jpg"/>
<img src="img/img03.jpg"/>
<img src="img/img04.jpg"/>
<img src="img/img01.jpg"/>
</div>
</div>
</body>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript">
var btns = $(".btn_list li");//数字按钮
var prevBtn = $(".prev");//上一页按钮
var nextBtn = $(".next");//下一页按钮
var scroll = $(".scroll");//滚动对象
var imgs = $(".scroll img");//图片
var width = $(".img_mod img:eq(0)").width();//图片宽度
var index = 0;//初始下标
var imgLength = imgs.length - 1;//最后一张图的下标
var lock = false;//锁,防止频繁操作发生错乱
//下一张按钮的点击事件
nextBtn.click(function(){
clearInterval(timer);
aa();
if (lock) {
return;
}
lock = true;
var left = parseInt(scroll.position().left);
//在原本最后一张图和结尾重复的第一张图之间时
if (left <= -(imgLength-1)*width && left > -imgLength*width) {
index = 0;
scroll.animate({
left : -imgLength*width
})
} else if(left <= -imgLength*width){//滚到结尾重复的第一张图时
//由于结尾重复的第一张图已经出现过,所以从第二张图开始继续新一轮滚动
index = 1;
scroll.css("left", 0);
scroll.animate({
left : -width
})
} else{
index++;
//边界值判断
index = index > imgLength ? imgLength - 1:index;
scroll.animate({
left : -index*width
})
}
//数字选中态
btns.eq(index).addClass("active").siblings().removeClass("active");
setTimeout(function(){
lock = false;
},500);
});
//上一张按钮的点击事件
prevBtn.click(function(){
clearInterval(timer);
aa();
if (lock) {
return;
}
lock = true;
var left = parseInt(scroll.position().left);
//在第一张图和第二张之间
if (left > -width && left <= 0) {
//index等于原本最后一张图的坐标
index = imgLength - 1;
//从重复的第一张滚到原本最后一张
scroll.css("left", -imgLength*width);
scroll.animate({
left : -index*width
});
} else{
index--;
//边界值判断
index = index < 0 ? 0:index;
scroll.animate({
left : -index*width
})
}
//数字选中态
btns.eq(index).addClass("active").siblings().removeClass("active");
setTimeout(function(){
lock = false;
},500);
});
//数字的点击事件
btns.click(function(){
clearInterval(timer);
aa();
index = $(this).index();
btns.eq(index).addClass("active").siblings().removeClass("active");
scroll.animate({
left : -index*width
})
});
var timer;
function aa(){
//自动轮播
timer = setInterval(function(){
index++;
if (index == imgLength) {
index = 0;
}
scroll.animate({
left : -index*width
})
btns.eq(index).addClass("active").siblings().removeClass("active");
},2000);
}
aa();
</script>
</html>
jQ版大图滚动的更多相关文章
- 一个jQ版大图滚动
难得周末能休息,也是越发的代码难受,手就想敲点东西,这不闲着无聊敲了一个Jq版的大图滚动,不足之处大家批评指正: 运作环境win7,代码编辑器是:sublime; 我把源码复制了一下, <!do ...
- 微博发布效果jq版
大家都看过新浪微博的发状态功能,我模拟了一下类似的效果,包括发布时间,删除效果等.代码如下: <!DOCTYPE HTML> <html> <head> <m ...
- 基于jQ+CSS3页面滚动内容元素动画特效
今天给大家分享一款基于jQ+CSS3页面滚动内容元素动画特效.这是一款基于jQuery+CSS3实现的页面滚动代码.该实例适用于适用浏览器:360.FireFox.Chrome.Safari.Oper ...
- 轮播图js版&jQ版
JS版轮播图 html部分和css部分自己任意定 主要构成: 1,一个固定的框 超出框的部分隐藏 2,几张图片float:left 3,下部下原点,点击切换,切换到不同的张都有红色显示 4,左右两个大 ...
- JQ封装切换滚动功能
/*---------控制滚动图片v1(作者:SFLYQ)-----------Options 配置对象,(用来配置控制元素的dom位置,初始化一些必要的对象或者方法)DoIni 初始化操作(初始化元 ...
- jquery版楼层滚动特效
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>楼 ...
- jq 版的tab切换
ta切换是在前端中非常常见的一种效果,网上的效果很多.但是我觉得下面这种方法最好,把tab效果封装成一个函数 tabs,这个函数要配合jq使用. var tabs = function (tab, c ...
- PC版模块滚动不显示滚动条效果
以前对某个模块增加无滚动条的滚动效果,还需要找个插件才能实现,现在发现个简单方法,用普通的CSS就可以实现. 此方法只适用于不显示滚动条的滚动效果,如果需要自定义滚动条样式,还是需要插件来实现. HT ...
- jq封装-无缝滚动效果
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
随机推荐
- mysql数据库(三):查询的其他用法
一. 查询—IN的用法 语法:select ... from 表名 where 字段 a in (值b, 值c, 值d...) 等价于 select ... from 表名 where 字段a=值b ...
- 析构函数和Dispose方法的区别
1. 析构函数(Finalize)只能释放非托管资源, 它是由GC调用. 2. Dispose方法可以释放托管资源和非托管资源,它是由用户手动调用的. 在Dispose()中调用 GC.Suppres ...
- 敏捷开发之scrum模型
什么是敏捷开发? 敏捷开发(Agile Development)是一种以人为核心.迭代.循序渐进的开发方法. 怎么理解呢?首先,我们要理解它不是一门技术,它是一种开发方法,也就是一种软件开发的流程,它 ...
- SpringMVC札集(01)——SpringMVC入门完整详细示例(上)
自定义View系列教程00–推翻自己和过往,重学自定义View 自定义View系列教程01–常用工具介绍 自定义View系列教程02–onMeasure源码详尽分析 自定义View系列教程03–onL ...
- 2017年终巨献阿里、腾讯最新Java程序员面试题,准备好进BAT了吗
Java基础 进程和线程的区别: Java的并发.多线程.线程模型: 什么是线程池,如何使用? 数据一致性如何保证:Synchronized关键字,类锁,方法锁,重入锁: Java中实现多态的机制是什 ...
- 【MFC】MFC绘图不闪烁——双缓冲技术
MFC绘图不闪烁——双缓冲技术[转] 2010-04-30 09:33:33| 分类: VC|举报|字号 订阅 [转自:http://blog.163.com/yuanlong_zheng@126/ ...
- The Pragmatic Programmer 摘要评注
这本书与其说是一本编程书,倒不如说是一本教做人的书.很多时候项目的进行依赖于技术以外的因素,比如说沟通,人的品格,人际,处理问题的方法.在未来的一度日子会陆续添加个人认为值得学习的内容.
- 【学习】Git和Github菜鸟入门
Git 是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理. 目录(自己创建吧) 生成ssh密钥:ssh-keygen -t rsa -C "邮箱" ...
- SGU 502 Digits Permutation
这个题目 正解应该是 dp 吧 对18个数字进行2进制枚举放不放,,,可以这么理解 以当前状态 stu,他对应的余数是 h 进入下一个状态: 进行记忆画搜索就行了 1 #include<iost ...
- 设计模式之访问者(visitor)模式
在患者就医时,医生会根据病情开具处方单,很多医院都会存在以下这个流程:划价人员拿到处方单之后根据药品名称和数量计算总价,而药房工作人员根据药品名称和数量准备药品,如下图所示. 在软件开发中,有时候也需 ...