当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 原JS实现banner图的常用功能

原JS实现banner图的常用功能

2017年12月12日  | 移动技术网IT编程  | 我要评论
虽然,用jquery实现banner图的各种效果十分简单快捷,但是我今天用css+js代码实现了几个banner图的常用功能,效果还不错。 此次,主要想实现以下功能:

虽然,用jquery实现banner图的各种效果十分简单快捷,但是我今天用css+js代码实现了几个banner图的常用功能,效果还不错。

此次,主要想实现以下功能:

  1. banner图循环不间断切换

  2. 通过自制按钮实现指定性banner图的切换

  3. 通过方向按钮实现banner图左/右定向依次切换

  4. 当banner图存在onmouseover事件时,停止banner切换,当存在onmouseout时继续切换

<!doctype html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      #banner{
        width: 716.8px;
        height: 537.6px;
        background-color: aquamarine;
        margin: 100px auto;
        position: relative;
        font-size: 0px;    /*清除img图片间的回车符产生的间隔*/
        overflow: hidden;
      }
      #banner #bannerimg{
        width: 100%;
        position: absolute;
        top: 0px;
        left: 0px;
        white-space: nowrap;  /*使这个图片能一行显示*/
        transition:all 1s linear;
      }
      #banner #bannerimg .img{
        width: 100%;
      }
      #banner #bannerbutton{
        font-size: 16px;
        color: white;
        position: absolute;
        bottom: 10px;
        left: 20px;
      }
      #banner #bannerbutton .button{
        border-radius: 9px;
        border: none;
        outline: none;
        cursor: pointer;
        background-color: #7fffd4;
      }
      #banner #bannerbuttonaside .div1{
        position: absolute;
        right: 10px;
        top: 50%;
        margin-top: -32px;
        cursor: pointer;
      }
      
      #banner #bannerbuttonaside .div2{
        position: absolute;
        left: 10px;
        top: 50%;
        margin-top: -32px;
        cursor: pointer;
      }
    </style>
  </head>
  <body>
    <!--实现 左右按钮,1234,自动滑动,鼠标停上显示小手不动 暂停。-->
    <section id="banner" onmouseover="changestop()" onmouseout="changestart()">
      
      <!--以下是我们的banner图-->
      <div id="bannerimg">
        <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/>
        <img class="img" src="../img/5f5bdebddd8f1d276aeac8af5f8fa38d.jpg"/>
        <img class="img" src="../img/5f5e5c091ecb0525fc8204f200670dd9.jpg"/>
        <img class="img" src="../img/efa11cad9094f951061ee21324277efe.jpg"/>
        <img class="img" src="../img/0b54c021bd4384c168d835dfc0908018.jpg"/>
        <img class="img" src="../img/25d10d413faca3bdd7e2d88667f4298f_看图王.jpg"/>
        <img class="img" src="../img/c95d7b9676ae739cccfc55457b93fe9c.jpg"/>  <!--第7张与第一张为同一图片,消除图片切换间断-->
      </div>
      
      <!--以下是我们左下方的banner图按钮-->
      <div id="bannerbutton">
        <button class="button" onclick="buttonchange(0)">1</button>
        <button class="button" onclick="buttonchange(1)">2</button>
        <button class="button" onclick="buttonchange(2)">3</button>
        <button class="button" onclick="buttonchange(3)">4</button>
        <button class="button" onclick="buttonchange(4)">5</button>
        <button class="button" onclick="buttonchange(5)">6</button>
      </div>
      
      <!--以下是我们左右两个方向按钮-->
      <div id="bannerbuttonaside">
        <div class="div1" onclick="asidechange(1)">
          <img src="../img/forword.png"/>
        </div>
        <div class="div2" onclick="asidechange(0)">
          <img src="../img/back.png"/>
        </div>
      </div>
    </section>
  </body>
  
  <script type="text/javascript">
    var bannerimg=document.getelementbyid("bannerimg");  /*取出img容器的节点*/
    var button=document.getelementsbyclassname("button");  /*取出所有的button按钮*/
    var num=0;   /*定义全局变量num,控制banner的切换次序*/
    var aaa=0;   /*定义一个全局变量,用来取定时器函数,并在没有鼠标事件的时候清除定时器*/
      
    /*通过定时器实现banner图的每3000毫秒切换一次的效果的changestart()函数*/
    function changestart(){
        aaa=setinterval(function(){
        if (num<=6) {
          bannerimg.style.transition="all 1s linear";
          bannerimg.style.left=(-716.8)*(num)+"px";
          num++;
        }else{
          bannerimg.style.transition="all 0s linear";    /*消除num=0时,bannerimg移动的过渡效果*/
          num=0;
          bannerimg.style.left=(-716.8)*(num)+"px";
          
        }
        console.log("哈哈哈继续");
      },3000)
    }
    changestart();
    
    /*以下是当鼠标悬浮在banner图上时,图片停止自动切换的changestop()函数*/
    function changestop(){
      clearinterval(aaa);  
      console.log("停止他");
    }
    
    /*以下是点击按钮实现对应banner图切换的change()函数*/
    function buttonchange(num){
      num=num+1;
      bannerimg.style.transition="all 0s linear";
      bannerimg.style.left=(-716.8)*(num)+"px";
    }
    
    /*以下是点击左右两个按钮实现banner图切换的buttonchange()函数*/
    function asidechange(x){  /*通过传递形参x,判断往左/往右切换banner图*/
      if (num!=6&&x==1) {
        num++;
      }else if(num==6&&x==1){
        num=0;
      }else if(num!=0&&x==0){
        num--;
      }
      else if(num==0&&x==0){
        num=5;
      }
      bannerimg.style.transition="all 0s linear";
      bannerimg.style.left=(-716.8)*(num)+"px";
    }
  </script>
</html> 

  但是经过博主的测试,发现程序存在一定的瑕疵,第一张图片的保留时间比其他图片长,而且每次重新开启定时器均存在这个问题。暂时博主还没有比较简单

省事的方法改良他,所以仅供参考思路,以后要用,当然还是jquery省事啦!

  如果存在错误,欢迎朋友们指出,我们一起探讨,改良代码!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网