1. <!DOCTYPE html>
    <html lang="en">
  2.  
  3. <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>图片切换</title>
    <style>
    .picture {
    position: relative;
    width: 500px;
    height: 333px;
    margin: 0 auto;
    border: 2px solid rgb(231, 127, 217);
    overflow: hidden;
    }
  4.  
  5. .radius { /* 圆点所在的p (容器) */
    width: 100%;
    height: 10px;
    position: absolute;
    bottom: 30px;
    text-align: center;
    }
  6.  
  7. .p
    g {
    position: absolute;
    margin: 0;
    width: 100%;
    height: 20px;
    background-color: rgba(0, 0, 0, .4);
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    }
  8.  
  9. .title {
    position: absolute;
    width: 100%;
    bottom: 0px;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
    color: rgb(21, 223, 72);
    }
  10.  
  11. span {
    display: inline-block;
    border: 10px solid #fdfdfd;
    border-radius: 50%;
    }
  12.  
  13. .active {
    border: 10px solid #656466;
    }
  14.  
  15. /* 左右箭头 */
    .arrowhead-left,
    .arrowhead-right {
    position: absolute;
    width: 41px;
    height: 69px;
    font-size: 30px;
    line-height: 70px;
    text-align: center;
    color: #D6D8D4;
    background-color: rgba(0,0,0,.3);
    }
  16.  
  17. .arrowhead-left {
    left: 0;
    top: 40%;
    }
  18.  
  19. .arrowhead-right {
    right: 0;
    top: 40%;
    }
    </style>
    </head>
  20.  
  21. <body>
    <div class="picture">
    <!-- 图片页码 -->
    <p class="pg">封面</p>
    <img src="./image/d8.jpeg" alt="">
  22.  
  23. <!-- 小圆点点 -->
    <p class="radius"></p>
    <!-- 图片的下面标题 -->
    <p class="title">标题</p>
  24.  
  25. <!-- 左右箭头 -->
    <div class="arrowhead-left" id="al"> < </div>
    <div class="arrowhead-right" id="ar"> > </div>
    </div>
  26.  
  27. <script>
    var address = ["./image/d1.jpeg", "./image/d2.jpeg", "./image/d3.jpeg", "./image/d4.jpeg", "./image/d5.jpeg", "./image/d7.jpeg"];
    // var imgs = document.getElementsByTagName("img");
    var imgs = document.querySelector("img");
    var len = address.length; //图片地址的数量为len
    var str = "";
    var pp = document.getElementsByTagName("p");//获取的是p标签的集合
    // var pp = document.querySelector("p"); //获取的是一个元素
    var al = document.getElementById("al");
    var ar = document.getElementById("ar");
    var n = 0 ;
  28.  
  29. //添加span标签(小圆点),个数为len个
    for (i = 0; i < len; i++) {
    str += ' <span></span>'
    }
    pp[1].innerHTML = str;
  30.  
  31. var spans = pp[1].getElementsByTagName('span'); //获取p[1]里所有span标签
    spans[0].className = 'active'; //给第一个span标签添加样式 active
  32.  
  33. for (i = 0; i < len; i++) {
    spans[i].index = i; //自定义索引值
  34.  
  35. spans[i].onmouseover = function () { //鼠标指向圆点时的事件
    for (i = 0; i < len; i++) {
    spans[i].className = ""; //通过循环,清除所有圆点的类名
    }
    n=this.index ;
    this.className = 'active'; //给鼠标移入的圆点添加类名
    imgs.src = address[this.index];
    pp[0].innerHTML = [this.index + 1] + "/6";
    pp[2].innerHTML = "风光" + [this.index + 1];
  36.  
  37. }
  38.  
  39. }
  40.  
  41. ar.onclick = function () { //右侧箭头,点击一次图片向右换一张
    n++;
    if (n>5) {
    n=0;
    }
    for (i = 0; i < len; i++) {
    spans[i].className = "";
    }
  42.  
  43. spans[n].className = "active";
    imgs.src = address[n];
    pp[0].innerHTML = (n+1) + "/6";
    pp[2].innerHTML = "风光" +(n+1);
  44.  
  45. }
  46.  
  47. al.onclick = function () { // //左侧箭头,点击一次图片向左换一张
    n--;
    if (n<0) {
    n=(len-1);
    }
    for (i = 0; i < len; i++) {
    spans[i].className = "";
    }
    spans[n].className = "active";
    imgs.src = address[n];
    pp[0].innerHTML = (n+1) + "/6";
    pp[2].innerHTML = "风光" +(n+1);
    }
  48.  
  49. setInterval(ar.onclick,3000); //添加定时器 setInterval(函数,间隔时间单位为毫秒)
    //此次添加的函数为点击右侧箭头,间隔为3秒
    </script>
    </body>
  50.  
  51. </html>

如何使用js实现轮播图的更多相关文章

  1. 原生js焦点轮播图

    原生js焦点轮播图主要注意这几点: 1.前后按钮实现切换,同时注意辅助图2.中间的button随着前后按钮对应切换,同时按button也能跳转到相应的index3.间隔调用与无限轮播.4.注意在动画时 ...

  2. 原生js实现轮播图

    原生js实现轮播图 很多网站上都有轮播图,但找到一个系统讲解的却很难,因此这里做一个简单的介绍,希望大家都能有所收获,如果有哪些不正确的地方,希望大家可以指出. 原理: 将一些图片在一行中平铺,然后计 ...

  3. js实现轮播图效果(附源码)--原生js的应用

    1.js实现轮播图效果 <!DOCTYPE html><html lang="en"><head> <meta charset=" ...

  4. js编写轮播图,广告弹框

    1.轮播图 js编写轮播图,需要用到setInterval(计时器):先给一个div,里面放轮播图的图片,将轮播图的图片明明为相同样式的:如:banner1.jpg,banner2.jpg,banne ...

  5. js实现轮播图

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

  6. 封装一个简单的原生js焦点轮播图插件

    轮播图实现的效果为,鼠标移入左右箭头会出现,可以点击切换图片,下面的小圆点会跟随,可以循环播放(为了方便理解,没有补2张图做无缝轮播).本篇文章的主要目的是分享封装插件的思路. 轮播图我一开始是写成非 ...

  7. 原生JS实现轮播图的效果

    原生JS实现轮播图的效果: 只要缕清了全局变量index的作用,这个轮播图也就比较容易实现了:另外,为了实现轮这个效果,有几处clearInterval()必须写上.废话不多说,直接上代码,修复了几个 ...

  8. 使用原生js将轮播图组件化

    代码地址如下:http://www.demodashi.com/demo/11316.html   这是一个轮播图组件,这里是代码地址,需要传入容器的id和图片地址,支持Internet Explor ...

  9. 用原生js封装轮播图

    原生js封装轮播图 对于初学js的同学来说,轮播图还是一个难点,尤其是原生js封装轮播图代码,下面是我之前做的一个轮播图项目中封装好的一些代码,有需要的同学可以看一下,有什么不懂的可以看注释,注释看不 ...

  10. 原生js焦点轮播图的实现

    继续学习打卡,武汉加油,逆战必胜!今日咱们主要探讨一下原生js写轮播图的问题, 简单解析一下思路: 1,首先写好css样式问题 2,考虑全局变量:自动播放的定时器,以及记录图片位置的角标Index 2 ...

随机推荐

  1. Our Journey of Dalian Ends && Our Journey of Xian Ends 最小费用最大流

    2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络赛Our Journey of Dalian Ends 题意:要求先从大连到上海,再从上海打西安,中途会经过其他城市,每个城市只能去一次,出一次, ...

  2. 微信小程序的分享功能-css文字超过两行隐藏

    .info{ width:100px; word-break:break-all; display:-webkit-box; -webkit-box-orient:vertical; -webkit- ...

  3. 数据结构实验之查找一:二叉排序树 (SDUT 3373)

    二叉排序树(Binary Sort Tree),又称二叉查找树(Binary Search Tree),也称二叉搜索树. #include <stdio.h> #include <s ...

  4. Java基础系列 - 接口(功能,用途和优势)

    package com.test1; /** * 接口的使用 */ public class test1 { public static void main(String[] args) { //创建 ...

  5. Dp优化之决策单调栈优化

    证明:g(i) ≤ g(j)   (i ≤ j) 令 d=g(i) , k<d , 设cut = x表示 f(i) = f(x) + w[x,i]    ( x < i ) 构造一个式子: ...

  6. dubbo zookeeper图解入门配置

    这次主要是对dubbo 和zookeeper的配置做个记录,以便以后自己忘记了,或者踩的坑再次被踩 快速阅读 zookeerer类似 springcloud中的Eureka都做为注册中心,用srpin ...

  7. jQuery中ajax如何返回值到上层函数

    jQuery中ajax如何返回值到上层函数 一.总结 一句话总结: ajax的同步操作即可,设置 async: false, 二.jquery的同步操作 var can_submit=true; $. ...

  8. 有关Python的import...和from...import...的区别

    1.语法分析:首先from A import a1 是从A模块导入a1工具(可以是某个 函数,全局变量,类),import A是导入整个A模块的全部内容(包括全部的函数,全局变量,类). 2.内存分析 ...

  9. vue官网笔记

    学习了vue后又重新过了一遍官网的教程,选择性地摘抄了一些自己觉得比较重要的知识点.以备后面查缺补漏用. 计算属性 计算属性mounted中,属性值函数将用作属性的getter函数.当函数中的依赖发生 ...

  10. Redis操作类型