真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

jquery如何寫出PC端輪播圖功能

這篇文章將為大家詳細(xì)講解有關(guān)jquery如何寫出PC端輪播圖功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

公司主營業(yè)務(wù):網(wǎng)站設(shè)計、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊有機(jī)會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出館陶免費做網(wǎng)站回饋大家。

最近其他項目不是很忙,被安排給公司的官網(wǎng)項目做一個新的頁面(之前沒接觸公司官網(wǎng)項目),其中有一個用到輪播圖的地方,最開始想直接用swiper.js插件實現(xiàn)就好了,可是發(fā)現(xiàn)官網(wǎng)項目里之前都沒有引入過swiper.js,后來想了想,就不引入它了,免得又得增加依次一次網(wǎng)絡(luò)請求,項目里既然已經(jīng)用到了jQuery,那就索性用jQuery寫一個輪播圖吧。

現(xiàn)在把自己寫的輪播圖這塊代碼單獨拿出來,做一個小demo寫在這里記錄一下(demo中輪播圖的圖片網(wǎng)上隨意找的)

實現(xiàn)的效果:

1、自動輪播(輪播時間間隔在js代碼中自定義)

2、點擊左右側(cè)按鈕,實現(xiàn)手動切換

3、底部小圓點根據(jù)切換圖片的位置相應(yīng)的顯示active狀態(tài)

4、鼠標(biāo)經(jīng)過輪播圖區(qū)域,停止輪播,離開輪播圖區(qū)域開始輪播

代碼目錄結(jié)果如下:

jquery如何寫出PC端輪播圖功能

一、index.html

注:這里以5張圖片為例,頁面上真正輪播展示給用戶看到的是5張不同的圖片,但是為了輪播效果的連貫性,所以在第一張圖片前面添加上第五張圖片,在第五張圖片后面加上了第一張圖片,所以demo結(jié)構(gòu)里是7張圖片,每張圖片的尺寸必須都是一樣的哦(這里寬高尺寸是720*350px)。




 
 PC-jquery版輪播圖
 



 PC-jquery版輪播圖
 
  
   
    
  • 圖片-5

  •     
  • 圖片-1

  •     
  •     
  •     
  •     
  •     
  •                         
  •     
  •     
  •     
  •       
                ?
       ?
        

    二、style.css

    * {
     margin: 0;
     padding: 0;
     box-sizing: border-box;
    }
    .layout {
     width: 1000px;
     margin: 30px auto;
    }
    ul,ol,li {
     list-style: none;
    }
    .slide {
     position: relative;
     width: 900px;
     margin:auto;
    }
    .slide .outer {
     position: relative;
     margin: 30px auto;
     width: 720px;
     height: 400px;
     overflow: hidden;
    }
    .slide .outer .inner {
     width: 5040px;
     height: 350px;
     position: absolute;
     left: -720px;
     top: 0;
    }
    .slide .outer .inner li {
     float: left;
     height: 350px;
    }
    .slide .outer .inner li a {
     display: block;
     position: relative;
     width: 100%;
     height: 100%;
    }
    .slide .outer .inner li a p {
     position: absolute;
     left: 0;
     bottom: 0;
     color: #fff;
     font-size: 18px;
     width: 720px;
     height: 80px;
     line-height: 80px;
     padding-left: 50px;
     background: linear-gradient(180deg,rgba(0,0,0,0), rgba(0,0,0,0.5));
    }
    .slide .outer .dot {
     margin-top: 365px;
     text-align: center;
    }
    .slide .outer .dot li {
     height: 6px;
     width: 6px;
     border-radius: 3px;
     background-color: #d2cbcb;
     display: inline-block;
     margin: 0 3px;
    }
    .slide .outer .dot li.active {
     background-color: #6e5ca5;
    }
    .slide .arrow-box {
     position: absolute;
     width: 900px;
     height: 60px;
     top: 150px;
     left: 0;
    }
    .slide .arrow-box .arrow {
     width: 60px;
     height: 60px;
     line-height: 60px;
     text-align: center;
     border-radius: 30px;
     background-color: #dde2e6;
     font-size: 60px;
     color: #999;
     cursor: pointer;
    }
    .slide .arrow-box .arrow.arrow-l {
     float: left;
    }
    .slide .arrow-box .arrow.arrow-r {
     float: right;
    }

    三、index.js

    注:js代碼中,每個變量均已給了注釋。為了防止快速多次點擊,而出現(xiàn)動畫不停的現(xiàn)象,這里在每次切換圖片的時候先調(diào)用stop(false,true)。但是注意在向左側(cè)滾動的時候,滾動到最后一張圖圖片后,再次切換時就不要用stop(false,true),而是要瞬間定位到第一張圖片(其實是dom結(jié)構(gòu)中的第二張)的位置,同樣,向右側(cè)滾動時,當(dāng)滾動到第一張圖片后,再次切換時就不用stop(false,true),而是要瞬間定位到最后一張圖片(其實是dom結(jié)構(gòu)中的倒數(shù)第二張)的位置。

    var interval = 3000;    //輪播間隔時間
    var arrowL = $('#arrow_l');   //左側(cè)箭頭
    var arrowR = $('#arrow_r');   //右側(cè)箭頭
    
    var slideBox = $('#slide');   //輪播圖區(qū)域
    var innerBox = $('#inner');   //內(nèi)層大盒子
    var img = innerBox.children('li'); //每個圖片
    var dot = $('#dot');    //小圓點盒子
    
    var imgW = $(img[0]).outerWidth(); //每個li標(biāo)簽的寬度
    
    var imgCount = 5;     //總圖片個數(shù)(不同圖片的個數(shù))(實際dom上是有7張)
    var i = 0;       //初始化為第0張圖片
    timer = null;      //定時器
    
    //自動輪播
    timer = setInterval(function () {
     i++;
     innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
     dot.find('li').removeClass('active').eq(i-1).addClass('active')
     if(i > imgCount){
      innerBox.animate({'left':-1*imgW+'px'},0);
      dot.find('li').removeClass('active').eq(0).addClass('active')
      i = 1;
     }
    },interval)
    
    //點擊右側(cè)箭頭,播放下一張
    arrowR.click(function () {
     i++;
     innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
     dot.find('li').removeClass('active').eq(i-1).addClass('active')
     if(i > imgCount){
      innerBox.animate({'left':-1*imgW+'px'},0);
      dot.find('li').removeClass('active').eq(0).addClass('active')
      i = 1;
     }
    })
    
    //點擊左側(cè)箭頭,播放上一張
    arrowL.click(function () {
     i--;
     innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
     dot.find('li').removeClass('active').eq(i-1).addClass('active')
     if(i < 1){
      innerBox.animate({'left':-imgCount*imgW+'px'},0);
      dot.find('li').removeClass('active').eq(imgCount-1).addClass('active')
      i = imgCount;
     }
    })
    //鼠標(biāo)經(jīng)過輪播圖區(qū)域時,清除定時器,停止自動輪播
    slideBox.mouseenter(function () {
     clearInterval(timer);
    })
    
    //鼠標(biāo)離開輪播圖區(qū)域時,重新啟動自動輪播
    slideBox.mouseleave(function () {
     timer = setInterval(function () {
      i++;
      innerBox.stop(false, true).animate({'left':-i*imgW+'px'},300)
      dot.find('li').removeClass('active').eq(i-1).addClass('active')
      if(i > imgCount){
       innerBox.animate({'left':-1*imgW+'px'},0);
       dot.find('li').removeClass('active').eq(0).addClass('active')
       i = 1;
      }
     },interval)
    })

    四、效果圖展示

    jquery如何寫出PC端輪播圖功能

    jquery如何寫出PC端輪播圖功能

    jquery如何寫出PC端輪播圖功能

    關(guān)于“jquery如何寫出PC端輪播圖功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。


    本文題目:jquery如何寫出PC端輪播圖功能
    網(wǎng)頁URL:http://weahome.cn/article/gccjsh.html

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部