用javascript图片轮播功能

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>图片轮播</title>
<style>
#swaper{
width: 520px;
margin: 0 auto;
}
#number{
position: relative;
top: -30px;
right: -320px;
}
label{
width: 10px;
height: 10px;
background-color: yellow;
margin: 2px; }
.active{
width: 10px;
height: 10px;
border: 1px solid black;
background-color: red;
}
</style>
<script>
//此处编写代码,实现图片轮播功能 </script>
</head>
<body>
<div id="swaper">
<img src="img/pic01.jpg" width="512px" id="img">
<div id="number">
<label id="l1" class="active">&nbsp;1&nbsp;</label>
<label id="l2">&nbsp;2&nbsp;</label>
<label id="l3">&nbsp;3&nbsp;</label>
<label id="l4">&nbsp;4&nbsp;</label>
<label id="l5">&nbsp;5&nbsp;</label>
<label id="l6">&nbsp;6&nbsp;</label>
</div>
</div>
</body>
</html>

  (第4和第5张图片是一样的,最下方有看鼠标点击时控制台输出的信息)

        <script>
//此处编写代码,实现图片轮播功能
var n =0;
var t =0;
var oDiv = document.getElementById('number');
var labels = document.getElementsByTagName('label');
window.onload = function(){
//加载页面时开始触发图片轮播
t=setTimeout(GaryShowPic,1000);
for(var i = 0;i<labels.length;i++){
//鼠标放置到下标上时
labels[i].onmouseover = function(){
//停止计时器
clearTimeout(t);
var b = this.innerText*1;
img.src = 'img/pic0'+b+'.jpg';
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
this.className = 'active'
}
//鼠标离开时
labels[i].onmouseout=function(){
//得到计数器文本下标,返回值是string类型
n=this.innerText*1;
//重新开始计时器
t=setTimeout(GaryShowPic,1000);
}
} function GaryShowPic(){
n++;
if(n>6){n=1;}
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
labels[n-1].className='active';
document.getElementById('img').src='img/pic0'+n+'.jpg';
t=setTimeout(GaryShowPic,1000);
}
}
</script>

Gary.Script

实现过程

  Window setInterval() 方法  传送门

  setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式

  setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数

  (如果只想执行一次可以使用 setTimeout() 方法)

  clearTimeout() 方法可取消由 setTimeout() 方法设置的定时操作。

  clearTimeout() 方法的参数必须是由 setTimeout() 返回的 ID 值。

  (要使用 clearTimeout() 方法, 在创建执行定时操作时要使用全局变量)

  t作为setInterval() 返回的 ID 值并且要使用clearTimeout(),开全局变量

    //作为轮播图片下标签
var n =0;
//由 setInterval() 返回的 ID 值
var t =0;

  播放图片方法

                function GaryShowPic(){
n++;
if(n>6){n=1;}
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
labels[n-1].className='active';
document.getElementById('img').src='img/pic0'+n+'.jpg';
t=setTimeout(GaryShowPic,1000);
}

  鼠标放置到下标上时

  labels[i].onmouseover = function(){
//停止计时器
clearTimeout(t);
//显示当前标签表示的图片
var b = this.innerText*1;
img.src = 'img/pic0'+b+'.jpg';
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
//将当前标签显示为红色
this.className = 'active'
}

  鼠标离开下标时,重新开始计时器

labels[i].onmouseout=function(){
//得到计数器文本下标,返回值是string类型
n=this.innerText*1;
//重新开始计时器
t=setTimeout(GaryShowPic,1000);
}

JavaScript中innerText和innerHTML的区别  传送门

innerText返回或者设置DOM元素的文本

innerHTML 返回或者设置DOM元素的子元素

返回元素上:  忽略和不忽略Html标签的区别

innerHTML:

  从对象的起始位置到终止位置的全部内容,包括Html标签

innerText:

  从起始位置到终止位置的内容, 但它去除Html标签

=================================分割线

使用console.log()在控制台中查看输出信息

  在鼠标触碰事件中添加 console.log("鼠标触碰到的下标值为"+b) 查看鼠标触碰到的数值

//鼠标触碰到标签上时
labels[i].onmouseover = function(){
//停止计时器
clearTimeout(t);
//显示当前标签表示的图片
var b = this.innerText*1;
console.log("鼠标触碰到的下标值为"+b);
img.src = 'img/pic0'+b+'.jpg';
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
//将当前标签显示为红色
this.className = 'active'
}

  在GaryShowPic()中添加 console.log(labels[n-1]) 查看所显示标签的信息

function GaryShowPic(){
n++;
if(n>6){n=1;}
//制空所有图片的style
for(var i=0;i<labels.length;i++){
labels[i].className='';
}
labels[n-1].className='active';
console.log(labels[n-1]);
document.getElementById('img').src='img/pic0'+n+'.jpg';
t=setTimeout(GaryShowPic,1000);
}

  console.log("鼠标触碰到的下标值为"+b)调试台输出的值是我们想要的

  console.log(labels[n-1])输出来的值就是下面body中的值

            <div id="number">
<label id="l1" class="active">&nbsp;1&nbsp;</label>
<label id="l2">&nbsp;2&nbsp;</label>
<label id="l3">&nbsp;3&nbsp;</label>
<label id="l4">&nbsp;4&nbsp;</label>
<label id="l5">&nbsp;5&nbsp;</label>
<label id="l6">&nbsp;6&nbsp;</label>
</div>

  可以看到,实现的轮播图改变的只是所指向的label id 标签值的class="active"

  

原生Js_使用setInterval() 方法实现图片轮播功能的更多相关文章

  1. 使用javascript,jquery实现的图片轮播功能

    使用javascript,jquery实现的图片轮播功能本功能采用最基础的javascript和一些简单的jquery技术实现,易理解,以修改使用,代码简易,适合刚开始接触到网站开发的朋友们参考.可以 ...

  2. 个人练习:使用HTML+CSS3制作图片轮播功能(不使用JavaScript)

    先上效果图,不要在意用来当素材的图片: 在搜索相关资料的时候,查到有两种实现方式:一是使用JavaScript,二是使用CSS3中的Animation(动画),这里使用的是CSS3中的Animatio ...

  3. 原生JS实现"旋转木马"效果的图片轮播插件

    一.写在最前面 最近都忙一些杂七杂八的事情,复习软考.研读经典...好像都好久没写过博客了... 我自己写过三个图片轮播,一个是简单的原生JS实现的,没有什么动画效果的,一个是结合JQuery实现的, ...

  4. 基于bootstrap的图片轮播功能

    插入js及css支持: <link rel="stylesheet" href="css/bootstrap.min.css"/> <scri ...

  5. 使用JS实现图片轮播(前后首尾相接)

    最近各种跑面试,终于还是被问到这个,一脑子浆糊,当时没想出来首尾相接怎么搞,回来之后研究了一波,终于搞出来了,不多说,直接看代码 代码参考了一位已经写好了图片轮播功能的(在此表示感谢),但是没有首尾相 ...

  6. javaScript实现图片滚动及一个普通图片轮播的代码

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. onethink插件二(首页图片轮播)

    2014年8月1日 15:34:15 基于slice-box 写了一个图片轮播的插件. 一.功能: 1.图片轮播功能 2.自定义功能(数量,效果,打开方式) 3.多重效果一键切换 4.独立性强,不影响 ...

  8. 原生Js_简易图片轮播模板

    功能:图片自动循环轮播,通过点击“上一张”,“下一张”按钮来控制图片的切换 <!DOCTYPE html> <html> <head> <meta chars ...

  9. 基于面向对象的图片轮播(js原生代码)

    无论你想走多远,你都需要不断地走下去.前端最精华的便是原生的js,这也是我们前端工程师的技术分层的重要指标,也提现这你的代码能力,开发的水平.废话不多说,进入今天的主要分享————基于面向对象思想的图 ...

随机推荐

  1. C++练习 | 单向链表类模板(包含类模板中静态变量初始化格式)

    #include <iostream> #include <string> using namespace std; template <class T> clas ...

  2. Codeforces 1229C. Konrad and Company Evaluation

    传送门 首先考虑如何算出答案,考虑枚举中间那个点,显然每个点作为中间的点的次数为入度乘出度 所以答案就是每个点的入度乘出度之和 然后每个点开一个 $vector$ 维护从它出去的点数,每次修改的时候直 ...

  3. 关于echarts中南海诸岛的显示问题

    1.china.js 文件中  echarts.registerMap('china',    //名字要是'china',不能写成'中国'   2.echarts 配置中地图名称 mapName: ...

  4. linux centos系统安装

    1.下载镜像 https://www.centos.org/download/ DVD ISO 一般下载这个 erverything ISO 包含所有工具的版本 Minimal ISO最小启动版本 2 ...

  5. Java加密数据库

    一.背景 数据库配置以明文方式展示如图,会造成安全隐患,如果有黑客入侵会造成密码泄露,信息窃取和破坏等. 二.加密步骤 1.对数据库信息加密: 对数据库中的账号和密码信息进行加密(选择一种算法)然后替 ...

  6. Java基础(那些习以为常缺不知道原理的地方)

    一.基础 1.1 正确的使用equals方法 Object的equals方法容易抛空指针异常,应使用常量或确定有值的对象来调用 equals.如下代码 // 不能使用一个值为null的引用类型变量来调 ...

  7. 分布式的几件小事(五)dubbo的spi思想是什么

    1.什么是SPI机制 SPI 全称为 Service Provider Interface,是一种服务发现机制. SPI 的本质是将接口实现类的全限定名配置在文件中,并由服务加载器读取配置文件,加载实 ...

  8. js判断变量是否为undefined

    可能很多朋友认为undefined是在js中未定义变量时才会提示的错误,其实不然undefined 是js中的一特殊的变量,我们也可以提前定义哦,下面我来介绍js undefined 用法. Java ...

  9. MyBatis--把SQL带进Java

    简单来看软件服务的工作流程:用户端界面操作请求<---->本地处理|远程服务程序拦截转发请求<---->服务端逻辑功能实现<--MyBatis用在这里-->数据库. ...

  10. SSD源码解读——损失函数的构建

    之前,对SSD的论文进行了解读,可以回顾之前的博客:https://www.cnblogs.com/dengshunge/p/11665929.html. 为了加深对SSD的理解,因此对SSD的源码进 ...