JQuery制作基础的无缝轮播与左右点击效果
在网页中我们想要的无缝轮播左右循环有好多好多中,这是我第一个轮播效果,也是最基础的,和大家分享一下,对于初学者希望你们能有所借鉴,对于大神我想让你们尽情的虐我给我宝贵的意见。
这个是我要的效果
进入正题,首先是布局,布局的原理就是在DIV中创建ul标签,ul中插入li标签,在里插入图片,你想要几个图片轮播,插入几个li。布局上主要的点在于div设置大小,加上overflow:hidden;让超出部分隐藏,ul的长度是所有图片的总长度,li浮动。
<div id="djlb">
<div id="bigul">
<ul>
<li>
<img src="../images/djlb1.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li>
</ul>
<ul>
<li>
<img src="../images/djlb2.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li> </ul>
<ul>
<li>
<img src="../images/djlb3.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li>
</ul>
<ul>
<li>
<img src="../images/djlb2.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li>
</ul>
<ul>
<li>
<img src="../images/djlb2.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li>
</ul>
<ul>
<li>
<img src="../images/djlb2.gif" alt="">
<p class="zt4">赵茜</p>
<p class="zt22">北京大学历史系研究生</p>
</li>
<li>
<img src="../images/yc2.gif" alt="yc2">
</li>
</ul>
</div>
</div>
<div id="aniu">
<div id="bleft"></div>
<div id="bright"></div>
</div> </div>
html代码
#djlb {
width: 1200px;
height: 600px;
overflow: hidden;
}
#bigul {
width: 1800px;
height: 560px;
}
#bigul > ul {
position: relative;
width: 300px;
height: 560px;
float: left;
}
#bigul > ul > li:nth-child(even) {
position: absolute;
display: none;
}
#bigul > ul > li {
width: 300px;
height: 560px;
float: left;
}
#aniu {
position: relative;
}
#aniu > div {
position: absolute;
}
#aniu > div:first-child{
left:-55px;
top: -290px;
display: inline-block;
border-left: 6px solid #c2c2c2;
border-top: 6px solid #c2c2c2;
width: 37px;
height: 37px;
transform: rotate(-45deg);
}
#aniu > div:last-child{
left: 1210px;
top: -290px;
display: inline-block;
border-right: 6px solid #c2c2c2;
border-bottom: 6px solid #c2c2c2;
width: 37px;
height: 37px;
transform: rotate(-45deg);
}
#aniu > div:first-child:hover{
border-left: 6px solid #ffcc00;
border-top: 6px solid #ffcc00;
}
#aniu > div:last-child:hover {
border-right: 6px solid #ffcc00;
border-bottom: 6px solid #ffcc00;
}
css代码
主要说明一下我js的思路;
$(function () {
var i = 0, tick, list, ul = $("#bigul");
$("#bright").click(function () {
$("#bigul").animate({ "margin-left": -300 }, 30000, function () {//当你执行完了后发生的事件
list =ul.find("ul"); //正常的话ul就是li,因为我这个需要鼠标浮动显示隐藏,结构一样
ul.append(list.first()); //ul追加到最后一个
ul.css("margin-left",0); //在每一次点击过后,margin-left初始化为零,为什么嘛要初始化呢? 思考一下?
});//这样就向右无限循环了,就像队列一样
if (tick) {
clearTimeout(tick);
} //清除上一次定时器
tick = setTimeout(function () {
$("#bright").click();
}, 30000); 定时器自动的部分
});
$("#bleft").click(function(){
list = ul.find("ul");
list.last().insertBefore(list.first()); // 当第一次点击时,把最后的搬到前面来,
ul.css("margin-left",-300);
ul.animate({ "margin-left": 0 }, 3000); //同样这个问题??
if (tick) {
clearTimeout(tick);
}
tick = setTimeout(function () {
$("#bleft").click();
}, 3000);
});
$("#bright").click(); //自动向右事件
});
现在和你说为什么,如果不初始化,你点击右边的时候,他会重第一张到第三张,因为当你把第一个搬到后面一个时,ul父盒子左边是0,下一次移动他会自动补全他的位置,也就是两个位置,所以直接就是第三张图了,我是画图才想明白的嘻嘻!
整个思路:
运用animate让li移动,
当向右点击时,运用append()方法把第一个张追加到最后一张,而且要每次移动要清除一下子。
向左点击时,运用insertBefore()把最后一张插入第一张,也要清除一下
tick是我们定义的定时器settimeout
最后一句就是自动向右事件了
鼠标移动显示隐藏就是用到了mouseout() 和show(),hide()就ok了
JQuery制作基础的无缝轮播与左右点击效果的更多相关文章
- jQuery插件slides实现无缝轮播图特效
初始化插件: slides是一款基于jQuery无缝轮播图插件,支持图内元素动画,可以自定义动画类型 1 2 3 4 5 6 7 8 9 10 $(".slideInner").s ...
- js、jQuery实现文字上下无缝轮播、滚动效果
因项目需要实现消息通知上下无缝轮播的效果,所以写了一下,在这个分享出来,希望再次遇到此需求的道友,可以直接拷贝来用,节约一点不必要的时间. 原生JS版本 <!DOCTYPE html> & ...
- 【实践】纯jquery实现图片滑动无缝轮播,带左右按钮及控制按钮
在此随笔之前,博主已经做过一次图片滑动轮播,如过你也有看过就会知道里面的效果在自动轮播的时候有一个不太美观的效果,就是当最后一张图片滑动切换到第一张图片的时候会看到一个快速向左滑动的效果,这是很不美观 ...
- jQuery插件实现左右无缝轮播
前段时间学习jQuery的时候,在网上找了个SuperSlide插件,做轮播图demo,感觉对于新人而言,还是挺容易上手的,代码量也少. 直接贴代码吧. 1.HTML <!DOCTYPE htm ...
- jquery制作一个简单的轮播
效果图: 演示地址: http://ae6623.cn/demo/slider/index.html 思路: 利用css的定位属性 left 进行调整图片的显示,每次点击上一页下一页按钮的时候,-图片 ...
- Jquery制作--焦点图左右轮播
公司项目经常用到轮播焦点图,于是自己写了一个纯jq形式的横向轮播焦点图,可点击小圆点或者左右按钮进行切换,属于定宽类型.改成自适应宽度的也不难,将css里面的bannerCon宽度改为百分比,再在js ...
- 记一个jquery 无缝轮播的制作方法
接触前端也很久了,今天才发现,要做好一个轮播,其实有很多东西需要考虑进去,否则做出来的轮播效果并不好,下面我就来做一个轮播,是依赖jquery来写的 1.要做轮播,首先需要的是HTML的内容,css的 ...
- Jquery无缝轮播图的制作
轮播是html页面中比较常见的一种展现形式,也是基础,把轮播图做好,是排版中比较关键的 1.首先是轮播的html元素放置:做轮播之前,要有一个初步的认识 2.每个元素的位置怎样摆放,也是很关键的,这里 ...
- jQuery图片无缝轮播
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
随机推荐
- 9.2、Libgdx的输入处理之鼠标、触摸和键盘
(官网:www.libgdx.cn) Libgdx支持的最主要的设备是desktop或浏览器的鼠标支持,Android的触摸屏支持和键盘的支持.我们接下来了解一下. 键盘 用户按下或释放一个按键生成了 ...
- SpriteBuilder中节点位置类型为百分比时不能定位的解决
Ball.ccb类型是Node,其中有个子节点为Color Node,其中物理使能. MainScene.ccb中加入一个物理节点,将Ball.ccb拖入其中,成为该物理节点的孩子,这时出现了一个&q ...
- [转]Android长度单位详解
android中定义的dimension单位有以下这些:px(Pixels ,像素):对应屏幕上的实际像素点.in(Inches ,英寸):屏幕物理长度单位.mm(Millimeters ,毫米):屏 ...
- Android源码浅析(一)——VMware Workstation Pro和Ubuntu Kylin 16.04 LTS安装配置
Android源码浅析(一)--VMware Workstation Pro和Ubuntu Kylin 16.04 LTS安装配置 最近地方工作,就是接触源码的东西了,所以好东西还是要分享,系列开了这 ...
- 【Qt编程】基于Qt的词典开发系列<三>--开始菜单的设计
这篇文章讲讲如何实现开始菜单(或者称为主菜单)的设计.什么是开始菜单呢?我们拿常用的软件来用图例说明,大多数软件的开始菜单在左下角,如下图: 1.window 7的开始菜单 2.有道词典的主菜单 3. ...
- 【Qt编程】Qt学习之Window and Dialog Widgets
Qt Creator 提供的默认基类只要QMainWindow.QWidget和QDialog三种.其中,QMainWindow是带有菜单栏和工具栏的主窗口类,QDialog是各种对话框的基类,这两个 ...
- 《java入门第一季》之面向对象(成员方法)
/* 类的组成:成员变量,成员方法 又加入了一个新的成员:构造方法. 以后再提(类的组成): 成员变量 构造方法 成员方法 根据返回值: void类型 非void类型 形式参数: 空参方法 非空参方法 ...
- TCP中的MSS解读(转)
本文摘录自TCP中的MSS解读. MSS 是TCP选项中最经常出现,也是最早出现的选项.MSS选项占4byte.MSS是每一个TCP报文段中数据字段的最大长度,注意:只是数据部分的字段,不包括TCP的 ...
- WINCE的批处理
WINCE上没有提供象window一样的bat文件,如果需要类似功能可以借助第三方程序MortScript MortScript是一个运行于WINCE上的免费脚本解释程序,脚本文件为.mscr或.mo ...
- 那些年Android开发中遇到的坑
使用静态变量来缓存数据时,不管是在Application类还是其他类,都要注意因应用重建而引发的问题. 使用DecorView作为PopupWindow的anchorView时,在华为P7中它是显示在 ...