亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

jquery實現(xiàn)無縫輪播圖

 更新時間:2022年05月09日 17:14:35   作者:boylzh  
這篇文章主要為大家詳細介紹了jquery實現(xiàn)無縫輪播圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了jquery實現(xiàn)無縫輪播圖的具體代碼,供大家參考,具體內(nèi)容如下

實現(xiàn)功能(無縫輪播圖Jquery)

利用移動定位進行無縫滾動,大體實現(xiàn)點擊切換圖片,每張圖片對應一個小圓點,并且小圓點點擊可以進行切換。鼠標移入停止圖片輪播

強調(diào)

jquery引入本地引入,你可以在網(wǎng)上導入
全局由index貫穿
動畫中的回調(diào)函數(shù)
flag標識,進行判斷動畫在執(zhí)行中還是執(zhí)行結(jié)束
對于圖片切換到第一張還是最后一張的處理

css代碼片段

* {
? ? padding: 0;
? ? margin: 0;
}
html,
body {
? ? height: 100%;
? ? overflow: hidden;
}
body{
? ? background: rgba(0, 0, 0, 0.2);
}
.box {
? ? width: 1000px;
? ? height: 80%;
? ? margin: 50px auto;
? ? position: relative;
? ? overflow: hidden;
? ? box-shadow: 2px 2px 15px #333333;
}

ul {
? ? height: 100%;
? ? position: absolute;
? ? display: flex;
}

ol,
ul,
li {
? ? list-style: none;
}

li {
? ? flex-shrink: 0;
? ? width: 1000px;
? ? height: 100%;
}

li>img {
? ? width: 100%;
? ? height: 100%;
}

button {
? ? width: 70px;
? ? height:50px;
? ? color: #f5f5f5;
? ? position: absolute;
? ? z-index: 3;
? ? top: 50%;
? ? transform: translateY(-50%);
? ? background: rgba(0, 0, 0, 0.2);
? ? border-radius:0 5px 5px 0;
? ? opacity: 0;
? ? border: none;
? ? cursor: pointer;
? ? outline: none;
? ? transition: all 1s;
}
.box:hover button{
? ? opacity: 1;
}
button:hover{
? ? background: rgba(0, 0, 0, 0.5);
}
.left{
? ? border-radius:0 5px 5px 0;
}
.right {
? ? border-radius:5px 0px 0px 5px;
? ? right: 0;
}
ol{
? ? width: 120px;
? ? display: flex;
? ?? ? /*進行水平布局,與float功能并無差異,此處用float也是可以的*/
? ? justify-content: space-between;
? ? position: absolute;
? ? bottom: 10px;
? ? left: 50%;
? ? transform: translateX(-50%);
}
ol li{
? ? border-radius: 50%;
? ? width: 10px;
? ? height: 10px;
? ? background-color: #fff;
? ? cursor: pointer;
? ?
}
.ac{
? ? width: 25px;?
? ? transition: width 1s;
? ? border-radius: 5px 5px 5px 5px;
}

html,js代碼片段

<!DOCTYPE html>
<html lang="en">

<head>
? ? <meta charset="UTF-8">

? ? <title>Document</title>
? ? <link rel="stylesheet" href="../css/icon/iconfont.css" >
? ? <link rel="stylesheet" href="../css/carousel.css" >
? ? <script src="../jquery-3.4.1.min.js"></script>
</head>

<body>
? ? <div class="box">
? ? ? ? <ul>
? ? ? ? ? ? <li><img src="../images/1.jpg" alt=""></li>
? ? ? ? ? ? <li><img src="../images/2.jpg" alt=""></li>
? ? ? ? ? ? <li><img src="../images/3.jpg" alt=""></li>
? ? ? ? ? ? <li><img src="../images/4.jpg" alt=""></li>
? ? ? ? ? ? <li><img src="../images/5.jpeg" alt=""></li>
? ? ? ? ? ? <li><img src="../images/6.jpg" alt=""></li>
? ? ? ? </ul>
? ? ? ? <button class="iconfont left">&#xe60d;</button>
? ? ? ? <button class="iconfont right">&#xe658;</button>
? ? ? ? <ol>
? ? ? ? </ol>
? ? </div>
? ? <script>
? ? ? ? const box = $(".box");
? ? ? ? const ul = $(box).children("ul");
? ? ? ? const img_li = $(ul).children("li");
? ? ? ? const len = $(img_li).length,
? ? ? ? ? ? width = $(box).width();//獲取box也就是li的寬
? ? ? ? var flag = false;?? ??? ?//定義一個標識,來進行判斷當次動畫是否已經(jīng)完成
? ? ? ? var index = 0, lastIndex = 0;?? ?//定義全局的index,與lastIndex,也就是一個起到下標的標識
? ? ? ? $(img_li).first().clone(true).appendTo($(ul))//克隆第一張圖片放在ul的最后
? ? ? ? //生成所有的ol>li即小圓點
? ? ? ? for (let i = 0; i < len; i++) {
? ? ? ? ? ? $("<li>").addClass(i === 0 ? "ac" : "").appendTo($("ol")); //三元運算符給addClass進行填值
? ? ? ? ? ? //給第一個小圓點進行默認樣式的設置
? ? ? ? }
? ? ? ? //小圓點點擊切換圖片
? ? ? ? $("ol li").on('click', function () {
? ? ? ? ? ? if (flag) return;?? ??? ?//標識動畫,動畫未完成時,取消掉點擊事件
? ? ? ? ? ? flag = true;?? ??? ??? ?//動畫完成是執(zhí)行點擊事件的代碼
? ? ? ? ? ? lastIndex = index;?? ??? ?//記錄上次的點擊的index的值
? ? ? ? ? ? index = $(this).index();?? ??? ?//將小圓點的小標賦值給index
? ? ? ? ? ? $("ol li").eq(lastIndex).removeClass("ac")
? ? ? ? ? ? $(this).addClass("ac");?? ??? ?//將樣式進行toggle
? ? ? ? ? ? $(ul).animate({ left: -index * width }, 1000, function () //jquery的自定義動畫方法
? ? ? ? ? ? ? ? flag = false;//回調(diào)函數(shù)將在動畫結(jié)束之后將標識變?yōu)閠rue,以便于執(zhí)行下一次點擊事件
? ? ? ? ? ? })
? ? ? ? })

? ? ? ? //點擊下一張進行切換
? ? ? ? $(".right").on('click', function () {
? ? ? ? ? ? if (flag) return;?? ??? ?
? ? ? ? ? ? flag = true;?? ??? ?
? ? ? ? ? ? lastIndex = index;?? ??? ?
? ? ? ? ? ? index++;?? ??? ?//將index進行++,使其向下一張輪播
? ? ? ? ? ? if (index === len) {?? ??? ?//當輪播到最后一張clone的圖片時
? ? ? ? ? ? ? ? index = 0;?? ??? ??? ??? ?//將index賦值為0,讓小圓點正常執(zhí)行
? ? ? ? ? ? ? ? $(ul).animate({ left: -len * width }, 1000, function () {//讓動畫繼續(xù)執(zhí)行到clone的那張圖片
? ? ? ? ? ? ? ? ? ? flag = false;?? ??? ?
? ? ? ? ? ? ? ? ? ? $(ul).css("left", 0)?? ?//當執(zhí)行到最后一張clone的圖片,執(zhí)行完成時,立馬瞬移到第一張圖片
? ? ? ? ? ? ? ? })
? ? ? ? ? ? }
? ? ? ? ? ? else {
? ? ? ? ? ? ? ? $(ul).animate({ left: -index * width }, 1000, function () {
? ? ? ? ? ? ? ? ? ? flag = false
? ? ? ? ? ? ? ? })
? ? ? ? ? ? }
? ? ? ? ? ? $("ol li").eq(lastIndex).removeClass("ac")?? ?//給相應的小圓點進行樣式設置
? ? ? ? ? ? $("ol li").eq(index).addClass("ac")

? ? ? ? })
? ? ? ? //點擊上一張進行切換
? ? ? ? //與點擊下一張進行切換思想一致
? ? ? ? $(".left").on('click', function () {
? ? ? ? ? ? if (flag) return;
? ? ? ? ? ? flag = true;
? ? ? ? ? ? lastIndex = index;
? ? ? ? ? ? index--;
? ? ? ? ? ? if (index < 0) {
? ? ? ? ? ? ? ? index = len - 1;
? ? ? ? ? ? ? ? $(ul).css("left", -len * width)
? ? ? ? ? ? ? ? $(ul).animate({ left: -index * width }, 1000, function () {
? ? ? ? ? ? ? ? ? ? flag = false;
? ? ? ? ? ? ? ? })
? ? ? ? ? ? }
? ? ? ? ? ? else {
? ? ? ? ? ? ? ? $(ul).animate({ left: -index * width }, 1000, function () {
? ? ? ? ? ? ? ? ? ? flag = false
? ? ? ? ? ? ? ? })
? ? ? ? ? ? }
? ? ? ? ? ? $("ol li").eq(lastIndex).removeClass("ac")?? ??? ?
? ? ? ? ? ? $("ol li").eq(index).addClass("ac")
? ? ? ? })
? ? ? ? //自動播放

? ? ? ? $(box[0]).hover(() => {
? ? ? ? ? ? clearInterval($(box)[0].timer)
? ? ? ? }, (function auto() {
? ? ? ? ? ? $(box)[0].timer = setInterval(() => { //立即執(zhí)行函數(shù),在最后返回出auto函數(shù),讓hover的leave有事件執(zhí)行
? ? ? ? ? ? ? ? $(".right").trigger('click');
? ? ? ? ? ? }, 2000);
? ? ? ? ? ? return auto;
? ? ? ? }
? ? ? ? )())? ?


? ? </script>
</body>

</html>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • jQuery層疊選擇器用法實例分析

    jQuery層疊選擇器用法實例分析

    這篇文章主要介紹了jQuery層疊選擇器用法,結(jié)合實例形式分析了jQuery層疊選擇器功能、用法及相關操作注意事項,需要的朋友可以參考下
    2019-06-06
  • jquery密碼強度校驗

    jquery密碼強度校驗

    這篇文章主要介紹了jquery密碼強度校驗,這是一個非常常見的功能,在輸入密碼的時候提示密碼的強度,本文使用jQuery來實現(xiàn),有需要的小伙伴可以參考下。
    2015-12-12
  • JQuery循環(huán)滾動圖片代碼

    JQuery循環(huán)滾動圖片代碼

    每次滾動的長度不要固定死,可以直接獲取圖片寬度作為滾動的長度。這樣當你的網(wǎng)站有很多地方需要這個效果的時候一個函數(shù)就可以搞定了
    2011-12-12
  • jquery實現(xiàn)九宮格大轉(zhuǎn)盤抽獎

    jquery實現(xiàn)九宮格大轉(zhuǎn)盤抽獎

    jQuery九宮格大轉(zhuǎn)盤抽獎代碼網(wǎng)頁特效,點擊抽獎按鈕開始隨機抽獎選擇獎品,可設置起點位置、獎品數(shù)量、轉(zhuǎn)動次數(shù)、中獎位置參數(shù)
    2015-11-11
  • 基于jQuery實現(xiàn)圖片的前進與后退功能

    基于jQuery實現(xiàn)圖片的前進與后退功能

    前進與后退在瀏覽網(wǎng)頁的時候是比較常見的而且非常的實用,接下來為大家分享下使用jQuery實現(xiàn)圖片的前進與后退,感興趣的朋友可以參考下哈
    2013-04-04
  • jQuery加載及解析XML文件的方法實例分析

    jQuery加載及解析XML文件的方法實例分析

    這篇文章主要介紹了jQuery加載及解析XML文件的方法,結(jié)合實例形式分析了xml文件的創(chuàng)建及jQuery針對xml文件的獲取、解析相關操作技巧,需要的朋友可以參考下
    2017-01-01
  • 快速解決jquery.touchSwipe左右滑動和垂直滾動條沖突

    快速解決jquery.touchSwipe左右滑動和垂直滾動條沖突

    這篇文章主要介紹了快速解決jquery.touchSwipe左右滑動和垂直滾動條沖突問題,感興趣的小伙伴們可以參考一下
    2016-04-04
  • jQuery+SpringMVC中的復選框選擇與傳值實例

    jQuery+SpringMVC中的復選框選擇與傳值實例

    下面小編就為大家分享一篇jQuery+SpringMVC中的復選框選擇與傳值實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • ajax+jQuery實現(xiàn)級聯(lián)顯示地址的方法

    ajax+jQuery實現(xiàn)級聯(lián)顯示地址的方法

    這篇文章主要介紹了ajax+jQuery實現(xiàn)級聯(lián)顯示地址的方法,涉及jQuery操作Ajax實現(xiàn)級聯(lián)顯示的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-05-05
  • Jquery UI震動效果實現(xiàn)原理及步驟

    Jquery UI震動效果實現(xiàn)原理及步驟

    如果你想你的博客頁面某些部分引起讀者的注意,你可以使這些部分震動,如廣告等等,今天這篇文章將介紹怎樣使你的頁面中的元素震動起來,感興趣的你可不要錯過了哦,或許對你學習jquery ui 有所幫助
    2013-02-02

最新評論