用jquery制作的简单轮播图
我也是进入H5前端的小菜鸟一枚,最近才进入jquery的学习,所以打算对自己的学习进行记录。
今天分享的是一个简单的轮播图,这个轮播图的特效很简单,能够进行图片的轮播以及点击相应图片,图片能够跳转到相应位置
首先书写的div部分
<div id="scrollPics">
<ul class="slider">
<li><img src="../images/1.jpg" alt=""></li>
<li><img src="../images/2.jpg" alt=""></li>
<li><img src="../images/3.jpg" alt=""></li>
<li><img src="../images/7.jpg" alt=""></li>
<li><img src="../images/5.jpg" alt=""></li>
</ul>
<ul class="num"></ul>
</div>
然后书写style样式部分
<style>
*{
margin: 0px;
padding: 0px;
}
ul{
list-style: none;
}
#scrollPics{
height: 420px;
width: 790px;
margin-bottom: 10px;
overflow: hidden;
position: relative;
top: 100px;
left:400px;
}
.slider{
margin-top: 0px;
}
.slider img{
width: 100%;
}
.num{
position: absolute;
right: 5px;
bottom: 5px;
}
.num li{
float: left;
color: #ff7300;
text-align: center;
line-height: 16px;
width: 16px;
height: 16px;
cursor: pointer;
overflow: hidden;
margin: 3px 1px;
border: 1px solid #ff7300;
background-color: white;
border-radius: 50%;
}
.num li.active{
color: #fff;
line-height: 21px;
width: 21px;
height: 21px;
font-size: 16px;
margin: 0 1px;
border: 0;
background-color: #ff7300;
font-weight: bold;
border-radius: 50%;
cursor: pointer;
}
</style>
最后是script部分
<script>
$(function () {
var slider =$("#scrollPics .slider");
//获取图片
var imgCon =$("#scrollPics .slider li");
//除第一张其余的图片全部隐藏
imgCon.not(imgCon.eq(0)).hide();
//定义页码
var num =$("#scrollPics .num")
//获取li标签的长度
//find()方法返回备选元素的后代元素
var len =slider.find("li").length;
var html_page ="";
index=0;
//添加页码
for (var i=0;i<len;i++){
if (i===0){
html_page+="<li class='active'>"+(i+1)+"</li>"
}
else {
html_page +="<li>"+(i+1)+"</li>"
}
}
//输出原点
num.html(html_page)
//显示索引对应的图片
function showPic(index) {
imgCon.eq(index).show().siblings("li").hide();
num.find("li").eq(index).addClass("active").siblings("li").removeClass("active")
}
//原点点击事件
$(".num li").click(function () {
index=$(this).index()
showPic(index)
})
//图片轮播
$("#scrollPics").hover(function () {
clearInterval(window.timer)
},function () {
window.timer =setInterval(function () {
showPic(index);
index++;
if (index ===len){
index =0
}
},2000)
}).trigger("mouseleave")//触发备选元素的指定事件 }) </script>
然后出现上图样式,最后因为是用jquery书写的代码,还要导入 <script src="../js/jquery-2.2.3.js"></script>
最后是完整代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JQ轮播图</title>
<script src="../js/jquery-2.2.3.js"></script>
<style>
*{
margin: 0px;
padding: 0px;
}
ul{
list-style: none;
}
#scrollPics{
height: 420px;
width: 790px;
margin-bottom: 10px;
overflow: hidden;
position: relative;
top: 100px;
left:400px;
}
.slider{
margin-top: 0px;
}
.slider img{
width: 100%;
}
.num{
position: absolute;
right: 5px;
bottom: 5px;
}
.num li{
float: left;
color: #ff7300;
text-align: center;
line-height: 16px;
width: 16px;
height: 16px;
cursor: pointer;
overflow: hidden;
margin: 3px 1px;
border: 1px solid #ff7300;
background-color: white;
border-radius: 50%;
}
.num li.active{
color: #fff;
line-height: 21px;
width: 21px;
height: 21px;
font-size: 16px;
margin: 0 1px;
border: 0;
background-color: #ff7300;
font-weight: bold;
border-radius: 50%;
cursor: pointer;
}
</style>
</head>
<body> <div id="scrollPics">
<ul class="slider">
<li><img src="../images/1.jpg" alt=""></li>
<li><img src="../images/2.jpg" alt=""></li>
<li><img src="../images/3.jpg" alt=""></li>
<li><img src="../images/7.jpg" alt=""></li>
<li><img src="../images/5.jpg" alt=""></li>
</ul>
<ul class="num"></ul>
</div>
<script>
$(function () {
var slider =$("#scrollPics .slider");
//获取图片
var imgCon =$("#scrollPics .slider li");
//除第一张其余的图片全部隐藏
imgCon.not(imgCon.eq(0)).hide();
//定义页码
var num =$("#scrollPics .num")
//获取li标签的长度
//find()方法返回备选元素的后代元素
var len =slider.find("li").length;
var html_page ="";
index=0;
//添加页码
for (var i=0;i<len;i++){
if (i===0){
html_page+="<li class='active'>"+(i+1)+"</li>"
}
else {
html_page +="<li>"+(i+1)+"</li>"
}
}
//输出原点
num.html(html_page)
//显示索引对应的图片
function showPic(index) {
imgCon.eq(index).show().siblings("li").hide();
num.find("li").eq(index).addClass("active").siblings("li").removeClass("active")
}
//原点点击事件
$(".num li").click(function () {
index=$(this).index()
showPic(index)
})
//图片轮播
$("#scrollPics").hover(function () {
clearInterval(window.timer)
},function () {
window.timer =setInterval(function () {
showPic(index);
index++;
if (index ===len){
index =0
}
},2000)
}).trigger("mouseleave")//触发备选元素的指定事件 }) </script>
</body>
</html>
用jquery制作的简单轮播图的更多相关文章
- JS---案例:简单轮播图
案例:简单轮播图 div叫盒子,里面包了2个小盒子,一个是inner,一个是square inner的div是放ul,里面有li,a,和图片 square的div里面放span,是轮播图的小点 < ...
- (新手向)基于Bootstrap的简单轮播图的手机实现
个人电脑里存了不少适合手机欣赏的图片,但是放手机里看是件很占据资源的事.鉴于家里有一台电脑经常开着,正好用来做家庭局域网共享,于是笔者就设想通过一种比较简单环保的思路.通过手机访问电脑内的图片. 首先 ...
- jQuery淡入淡出效果轮播图
用JavaScript做了平滑切换的焦点轮播图之后,用jQuery写了个简单的淡入淡出的轮播图,代码没有做优化,html结构稍微有一些调整,图片部分用ul替换了之前用的div. html结构如下: & ...
- 手把手原生js简单轮播图
在团队带人,突然被人问到轮播图如何实现,进入前端领域有一年多了,但很久没自己写过,一直是用大牛写的插件,今天就写个简单的适合入门者学习的小教程.当然,轮播图的实现原理与设计模式有很多种,我这里讲的是用 ...
- jquery手写焦点轮播图-------解决最后一张无缝跳转第一张的问题
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js写的简单轮播图
这个轮播图代码是从网上找来的,专门找了个写法简单的,只是作为一个小练习,大概原理如下: 1.首先是图片切换2.自动播放3.调用自动播放4.移动到容器上边停止播放,离开自动播放5.移动到导航上停止播放, ...
- 原生js简单轮播图 代码
在团队带人,突然被人问到轮播图如何实现,进入前端领域有一年多了,但很久没自己写过,一直是用大牛写的插件,今天就写个简单的适合入门者学习的小教程.当然,轮播图的实现原理与设计模式有很多种,我这里讲的是用 ...
- 【前端】javascript+jQuery实现旋转木马效果轮播图slider
实现效果: 实现原理: 技术栈: javascript+jQuery+html+css 实现步骤: // 0. 获取元素 // 1. 鼠标放置到轮播图上,显示两侧的控制按钮,移开后隐藏 // 2. 为 ...
- jQuery实现todo及轮播图
内容: 1.todo程序 2.轮播图 1.todo程序 需求: 实现一个todo程序,可以添加数据,可以删除数据,可以修改数据,可以查看所有数据 另外实现自己的一系列弹窗:用于提示用户的提示框.用于警 ...
随机推荐
- 原生js控制控制--弹窗的显示和隐藏
以防浪费大家的时间,还是先上效果图吧,满足您的需求就往下look吧. 重要知识点:点击其他地方,也就是除了小叉子之外的地方也能够关闭弹窗哦.代码已标红 html代码: <button id ...
- spring mvc 数据校验(bean实体注解实现)
spring mvc 数据校验 1.添加个jar (jar与一版本会冲突) <dependency> <groupId>com.fasterxml</groupId> ...
- Java语言基础(方法重载概述和基本使用)
方法重载概述: 在同一个类中,允许存在一个以上的同名方法,只要他们的参数列表不同(即参数类型或者参数个数)即可. 方法重载特点: 1. 与返回值类型无关,只看方法名和参数列表 2. 在调用的时候,虚拟 ...
- [HTML]时钟
<div class="clock" id="clock"> <!-- 原点 --> <div class="origi ...
- UE4 Pro Tips(keeps updating)
Consolidate 功能 :在工程范围内用一种资源替换另外一种或多种资源具体操作:同时在编辑器中选中两个或多个资源,右键>Asset Actions>Replace Reference ...
- 大数据笔记(十四)——HBase的过滤器与Mapreduce
一. HBase过滤器 1.列值过滤器 2.列名前缀过滤器 3.多个列名前缀过滤器 4.行键过滤器5.组合过滤器 package demo; import javax.swing.RowFilter; ...
- node.js安装和配置(windows系统)
node.js安装和配置(windows系统) node javasript vscode node是javascript的管理工具,所以开发javasript项目都要下载安装和配置node. 传送 ...
- Linux驱动开发5——同步机制
上一章讲到了并发,指的是多个进程同时存取临界区资源的处理机制.这一章讲的同步机制,讲的是多个进程之间协同工作的处理机制,如临界区数据还没有准备好,A进程负责准备数据,B进程等待A进程完成之后读取数据. ...
- JS text节点无innerHTML
在线预览 text节点无innerHTML这个属性!!! 如果直接修改text节点的属性(data,nodeValue,textContent),或者使用js原生的修改text节点的内容的方法都会将H ...
- 010-Spring Boot 扩展分析-ApplicationContextInitializer、CommandLineRunner、ApplicationRunner
一.常见的两个扩展点 1.ApplicationContextInitializer 1.1.作用实现 作用:接口实在Spring容器执行refresh之前的一个回调. Callback interf ...