溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在JavaScript中使用JQuery實(shí)現(xiàn)一個(gè)輪播圖效果

發(fā)布時(shí)間:2020-12-31 15:10:44 來源:億速云 閱讀:169 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)如何在JavaScript中使用JQuery實(shí)現(xiàn)一個(gè)輪播圖效果,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

代碼:

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>無縫輪播圖</title>
</head>
<style type="text/css">
  * {
    margin: 0;
    padding: 0;
    list-style: none;
    text-decoration: none;
  }

  #container {
    position: relative;
    /*輪播圖容器的寬高*/
    width: 500px;
    height: 260px;
    margin: 20px auto;
    overflow: hidden;
    /*溢出隱藏:只顯示一張圖片*/
  }

  #container .wrapper {
    position: absolute;
    top: 0;
    left: 0;
    /*每張圖片的寬度和輪播圖容器的寬度相等,
    整個(gè)圖片層長(zhǎng)度:500*5=2500,由于克隆了一張,多加一張寬度*/
    width: 3000px;
    height: 100%;
  }

  #container .wrapper li {
    width: 500px;
    height: 100%;
    float: left;
  }

  #container .wrapper li img {
    width: 100%;
    height: 100%;
    vertical-align: middle;
    /*去掉未浮動(dòng)時(shí)圖片間的上下空隙*/
  }

  #container .btnLeft,
  #container .btnRight {
    display: none;
    z-index: 999;
    width: 30px;
    height: 30px;
    position: absolute;
    top: 50%;
    margin-top: -15px;
    background-color: #9E9E9E;
    border-radius: 20%;
    opacity: 60%;
    font-size: 20px;
    color: #673ab7;
    text-align: center;
    line-height: 30px;
  }

  #container .btnLeft {
    left: 0;
  }

  #container .btnRight {
    right: 0;
  }

  #container .btnLeft:hover,
  #container .btnRight:hover {
    opacity: 70%;
    cursor: pointer;
  }

  /* 鼠標(biāo)滑過圖片的時(shí)候顯示按鈕 */
  #container:hover .btnLeft,
  #container:hover .btnRight {
    display: block;
  }

  /*圓點(diǎn)層*/
  #container .dots {
    background: rgba(0, 0, 0, .3);
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    z-index: 999;
    padding: 4px;
    border-radius: 24px;
  }

  #container .dots li {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: #9e9e9e;
    float: left;
    /*可以使用行塊盒*/
    /*display: inline-block;*/
    margin: 0 5px;
    cursor: pointer;
  }

  #container .dots li.active {
    background-color: #c74b42;
  }

  .clearfix::after {
    content: "";
    display: block;
    clear: both;
  }
</style>

<body>
  <!-- 實(shí)現(xiàn)輪播圖的容器 -->
  <div id="container">
    <!-- 存放全部圖片的容器 -->
    <div class="wrapper">
      <!-- LI: 每張圖片 -->
      <li><img src="0.jpg"></li>
      <li><img src="1.jpg"></li>
      <li><img src="2.jpg"></li>
      <li><img src="3.jpg"></li>
      <li><img src="4.jpg"></li>
      <!-- 克隆到末尾 -->
      <li><img src="0.jpg"></li>
    </div>

    <div class="btnLeft">&lt;</div>
    <div class="btnRight">&gt;</div>
    <!-- 分頁器:圓點(diǎn) -->
    <div class="dots">
      <ul class="clearfix">
        <li class="active"></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ul>
    </div>
  </div>
  <script src="jquery-1.11.3.min.js"></script>
  <!-- <script src="index.js"></script> -->
  <script type="text/javascript">

    let $container = $('#container'),
      $wrapper = $container.children('.wrapper'),
      $btnLeft = $container.find('.btnLeft'),
      $btnRight = $container.find('.btnRight'),
      $dots = $container.find('.dots'),
      $dotList = $dots.find('li');

    let autoTimer = null,
      interval = 2000,
      imgIndex = 0; //當(dāng)前輪播的圖片索引,默認(rèn)第一張
    // 自動(dòng)輪播
    function autoPlay() {
      // 讓wrapper向左移動(dòng)
      imgIndex++;
      /* if(imgIndex === 4) imgIndex = 0; 這樣寫會(huì)導(dǎo)致圖片會(huì)一下變到第一張,不是無縫滾動(dòng)
      無縫滾動(dòng):
      1. 把第一張克隆一份放到末尾,wrapper中會(huì)比真實(shí)的圖片層多一張
      2. 依然一張張往后滾動(dòng),滾動(dòng)到第5張的時(shí)候,繼續(xù)向后走(imgIndex=6),看到了克隆的第一張,再要向后走的時(shí)候,
        讓其“立即”跳轉(zhuǎn)到真實(shí)的第一張(肉眼看不出跳轉(zhuǎn)),然后運(yùn)動(dòng)到第二張......
      */
      if (imgIndex > 5) {
        // 上次顯示的是克隆的那張,忽略真實(shí)的第一張,讓其立即跳轉(zhuǎn)到第二張
        $wrapper.css('left', 0);
        imgIndex = 1;
      }

      // 勻速向左移動(dòng)
      // 無動(dòng)畫版:$wrapper.css('transform', 'translate(' + (-imgIndex * 500) + 'px)');
      // 動(dòng)畫版:
      $wrapper.stop().animate({
        left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
      }, 300);

      showDots();
    }
    autoTimer = setInterval(autoPlay, interval);

    // 圓點(diǎn)對(duì)焦
    function showDots() {
      // 由于不能修改imgIndex的值,所以定義一個(gè)臨時(shí)變量
      let temp = imgIndex;
      temp === 5 ? temp = 0 : null;
      $dotList.each((index, item) => {
        let $item = $(item);
        if (index === temp) {
          $item.addClass('active');
          return;
        }
        $item.removeClass('active');
      });
    }

    // 鼠標(biāo)進(jìn)入/離開輪播區(qū)域時(shí)停止/開啟自動(dòng)輪播
    $container.on('mouseenter', () => {
      clearInterval(autoTimer);
    });

    $container.on('mouseleave', () => {
      autoTimer = setInterval(autoPlay, interval);
    });

    // 點(diǎn)擊圓點(diǎn)
    $dotList.click(function () {
      let index = $(this).index();
      imgIndex = index;

      $wrapper.stop().animate({
        left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
      }, 300);

      showDots();
    });

    // 左鍵點(diǎn)擊
    $btnLeft.click(function () {
      imgIndex--;
      if (imgIndex < 0) {
        // 上次顯示的是真實(shí)的第一張,忽略克隆的倒數(shù)第一張,讓其立即跳轉(zhuǎn)倒數(shù)第二張
        $wrapper.css('left', -2500);
        imgIndex = 4;
      }

      $wrapper.stop().animate({
        left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
      }, 300);

      showDots();
    });

    // 右鍵點(diǎn)擊:相當(dāng)于自動(dòng)輪播
    $btnRight.click(function() {
      autoPlay();
    });

  </script>

</body>

</html>

這段代碼用單例模式優(yōu)化一下:

html部分:test.html

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <title>無縫輪播圖</title>
</head>
<style type="text/css">
  * {
    margin: 0;
    padding: 0;
    list-style: none;
    text-decoration: none;
  }

  #container {
    position: relative;
    /*輪播圖容器的寬高*/
    width: 500px;
    height: 260px;
    margin: 20px auto;
    overflow: hidden;
    /*溢出隱藏:只顯示一張圖片*/
  }

  #container .wrapper {
    position: absolute;
    top: 0;
    left: 0;
    /*每張圖片的寬度和輪播圖容器的寬度相等,
    整個(gè)圖片層長(zhǎng)度:500*5=2500,由于克隆了一張,多加一張寬度*/
    width: 3000px;
    height: 100%;
  }

  #container .wrapper li {
    width: 500px;
    height: 100%;
    float: left;
  }

  #container .wrapper li img {
    width: 100%;
    height: 100%;
    vertical-align: middle;
    /*去掉未浮動(dòng)時(shí)圖片間的上下空隙*/
  }

  #container .btnLeft,
  #container .btnRight {
    display: none;
    z-index: 999;
    width: 30px;
    height: 30px;
    position: absolute;
    top: 50%;
    margin-top: -15px;
    background-color: #9E9E9E;
    border-radius: 20%;
    opacity: 60%;
    font-size: 20px;
    color: #673ab7;
    text-align: center;
    line-height: 30px;
  }

  #container .btnLeft {
    left: 0;
  }

  #container .btnRight {
    right: 0;
  }

  #container .btnLeft:hover,
  #container .btnRight:hover {
    opacity: 70%;
    cursor: pointer;
  }

  /* 鼠標(biāo)滑過圖片的時(shí)候顯示按鈕 */
  #container:hover .btnLeft,
  #container:hover .btnRight {
    display: block;
  }

  /*圓點(diǎn)層*/
  #container .dots {
    background: rgba(0, 0, 0, .3);
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    z-index: 999;
    padding: 4px;
    border-radius: 24px;
  }

  #container .dots li {
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background-color: #9e9e9e;
    float: left;
    /*可以使用行塊盒*/
    /*display: inline-block;*/
    margin: 0 5px;
    cursor: pointer;
  }

  #container .dots li.active {
    background-color: #c74b42;
  }

  .clearfix::after {
    content: "";
    display: block;
    clear: both;
  }
</style>

<body>
  <!-- 實(shí)現(xiàn)輪播圖的容器 -->
  <div id="container">
    <!-- 存放全部圖片的容器 -->
    <div class="wrapper">
      <!-- LI: 每張圖片 -->
      <li><img src="0.jpg"></li>
      <li><img src="1.jpg"></li>
      <li><img src="2.jpg"></li>
      <li><img src="3.jpg"></li>
      <li><img src="4.jpg"></li>
      <!-- 克隆到末尾 -->
      <li><img src="0.jpg"></li>
    </div>

    <div class="btnLeft">&lt;</div>
    <div class="btnRight">&gt;</div>
    <!-- 分頁器:圓點(diǎn) -->
    <div class="dots">
      <ul class="clearfix">
        <li class="active"></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ul>
    </div>
  </div>
  <script src="jquery-1.11.3.min.js"></script>
  <script src="index.js"></script>

</body>

</html>

JS部分:index.js

function debounce(func, wait, immediate) {
  let timer = null,
    result = null;
  return function anonymous(...args) {
    let context = this,
      now = immediate && !timer;
    clearTimeout(timer);
    timer = setTimeout(() => {
      timer = null;
      !immediate ? (result = func.call(context, ...args)) : null;
    }, wait);
    now ? (result = func.call(context, ...args)) : null;
    return result;
  };
}

let bannerModule = (function () {
  let $container = $("#container"),
    $wrapper = $container.children(".wrapper"),
    $btnLeft = $container.find(".btnLeft"),
    $btnRight = $container.find(".btnRight"),
    $dots = $container.find(".dots"),
    $dotList = $dots.find("li");

  let autoTimer = null,
    interval = 2000,
    imgIndex = 0; //當(dāng)前輪播的圖片索引,默認(rèn)第一張
  // 自動(dòng)輪播
  function autoPlay() {
    // 讓wrapper向左移動(dòng)
    imgIndex++;
    /* if(imgIndex === 4) imgIndex = 0; 這樣寫會(huì)導(dǎo)致圖片會(huì)一下變到第一張,不是無縫滾動(dòng)
        無縫滾動(dòng):
        1. 把第一張克隆一份放到末尾,wrapper中會(huì)比真實(shí)的圖片層多一張
        2. 依然一張張往后滾動(dòng),滾動(dòng)到第5張的時(shí)候,繼續(xù)向后走(imgIndex=6),看到了克隆的第一張,再要向后走的時(shí)候,
          讓其“立即”跳轉(zhuǎn)到真實(shí)的第一張(肉眼看不出跳轉(zhuǎn)),然后運(yùn)動(dòng)到第二張......
        */
    if (imgIndex > 5) {
      // 上次顯示的是克隆的那張,忽略真實(shí)的第一張,讓其立即跳轉(zhuǎn)到第二張
      $wrapper.css("left", 0);
      imgIndex = 1;
    }

    // 勻速向左移動(dòng)
    // 無動(dòng)畫版:$wrapper.css('transform', 'translate(' + (-imgIndex * 500) + 'px)');
    // 動(dòng)畫版:
    $wrapper.stop().animate({
      left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
    }, 300);

    showDots();
  }

  // 圓點(diǎn)對(duì)焦
  function showDots() {
    // 由于不能修改imgIndex的值,所以定義一個(gè)臨時(shí)變量
    let temp = imgIndex;
    temp === 5 ? (temp = 0) : null;
    $dotList.each((index, item) => {
      let $item = $(item);
      if (index === temp) {
        $item.addClass("active");
        return;
      }
      $item.removeClass("active");
    });
  }

  //點(diǎn)擊圓點(diǎn)
  function clickDots() {
    $dotList.click(debounce(function () {
      let index = $(this).index();
      imgIndex = index;

      $wrapper.stop().animate({
        left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
      }, 300);

      showDots();
    },300,true));
  }

  // 左右按鍵
  function btnClick() {
    $btnLeft.click(function () {
      imgIndex--;
      if (imgIndex < 0) {
        // 上次顯示的是真實(shí)的第一張,忽略克隆的倒數(shù)第一張,讓其立即跳轉(zhuǎn)倒數(shù)第二張
        $wrapper.css('left', -2500);
        imgIndex = 4;
      }

      $wrapper.stop().animate({
        left: -imgIndex * 500 //JQ自動(dòng)補(bǔ)'px'
      }, 300);

      showDots();
    });

    // 右鍵點(diǎn)擊:相當(dāng)于自動(dòng)輪播
    $btnRight.click(debounce(autoPlay, 300, true));
  }

  return {
    init: function () {
      autoTimer = setInterval(autoPlay, interval);

      // 鼠標(biāo)進(jìn)入/離開輪播區(qū)域時(shí)停止/開啟自動(dòng)輪播
      $container.on("mouseenter", () => {
        clearInterval(autoTimer);
      });
      $container.on("mouseleave", () => {
        autoTimer = setInterval(autoPlay, interval);
      });

      clickDots();
      btnClick();
    },
  };
})();

bannerModule.init();

上述就是小編為大家分享的如何在JavaScript中使用JQuery實(shí)現(xiàn)一個(gè)輪播圖效果了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI