js原生實現輪播

来源:https://www.cnblogs.com/donghuang/archive/2018/06/03/9119810.html
-Advertisement-
Play Games

通過對img opacity樣式的修改,達到對img顯隱的控制,從而形成輪播 ...


  前兩天同事面試新人,讓現場寫”輪播的實現”。我一想這玩意貌似我也沒寫過啊,就在旁邊暗搓搓地拖了一張紙也在那寫,同事都納悶了!

這玩意實現方法有很多種,就看喜歡那種,喜歡怎麼寫而已。我這裡是通過對img opacity樣式修改,達到對img顯隱的控制。img輪播到那個位置,就對該位置的img樣式進行設置,首先將上一張img樣式opacity變為0,然後將新位置img樣式opacity設置為1,從而形成輪播。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
        }
        .main,.scollimg,img{
            width: 1500px;
            height: 800px;
        }

        .main {
            margin: 0 auto;
            position: relative;
        }

        .main .scollimg {
            position: relative;
        }

        .main .scollimg img {
            position: absolute;
            top: 0;
            left: 0;
        }

        .main .item {
            position: absolute;
            bottom: 30px;
            left: 70px;
            width: 200px;
            height: 16px;
        }

        .main .item span {
            width: 16px;
            height: 16px;
            background-color: #ffffff;
            display: inline-block;
            border-radius: 50%;
        }

        .main .item span:hover {
            cursor: pointer;
        }

        .arrow {
            position: absolute;
            top: 280px;
            z-index: 2;
            display: none;
            width: 40px;
            height: 40px;
            font-size: 36px;
            font-weight: bold;
            line-height: 39px;
            text-align: center;
            color: #ffffff;
            background-color: rgba(0, 0, 0, 0.3);
            cursor: pointer;
        }

        .arrow:hover {
            background-color: rgba(0, 0, 0, 0.7);
        }

        .main:hover .arrow {
            display: block;
        }

        #btnleft {
            left: 20px;
        }

        #btnright {
            right: 20px;
        }
    </style>
</head>
<body>
<div class="main">
    <div class="scollimg">
        <img src="img/1.jpg" alt="">
        <img src="img/2.jpg" alt="">
        <img src="img/3.jpg" alt="">
        <img src="img/4.jpg" alt="">
        <img src="img/5.jpg" alt="">
    </div>
    <div class="btn">
        <a href="javascript:;" id="btnleft" class="arrow">&lt;</a>
        <a href="javascript:;" id="btnright" class="arrow">&gt;</a>
    </div>
    <div class="item">
        <span data-index="0"></span>
        <span data-index="1"></span>
        <span data-index="2"></span>
        <span data-index="3"></span>
        <span data-index="4"></span>
    </div>
</div>
<script type="text/javascript">
    var autoMove = {
        imgs: null,        //img節點數量(圖片數量)
        spans: null,       //span節點數量(左下角圓圈)
        count: 0,          //對輪播播放到那張圖片進行計數
        scollMove: -1,     //span節點數量(左下角圓圈)
        lastNode: 0,       //上一張img和span索引位置
        //通過對img opacity修改,達到對img顯隱的控制
        //index: 輪播索引。img輪播到那個位置,就對該位置的img樣式進行設置。首先將上一張img樣式opacity變為0,然後將index位置img樣式opacity設置為1
        styleMovement: function (index) {
            var tempLastNode = this.lastNode, tempImgs = this.imgs, tempSpans = this.spans;
            tempImgs[tempLastNode].style.opacity = "0";
            tempSpans[tempLastNode].style.background = "#ffffff";
            tempImgs[index].style.opacity = "1";
            tempSpans[index].style.background = "#ff0000";
            this.lastNode = index;
        },
        //輪播按count計數進行切換。初始化時顯示第一張圖片,然後隱藏第一張圖片顯現第二張圖片,以此類推
        //此處count從1開始計數(初始化時count為0),依次執行。當count===imgs.length時,由於圖片最後一張的imgs索引是imgs.length-1,故將count重置為0,起到一個輪循作用,依次重新開始。
        shiftMovement: function () {
            autoMove.styleMovement(this.count++);
            if (this.count === this.imgs.length) {
                this.count = 0;
            }
        },
        //按鈕和點擊操作
        btnAction: function (type) {
            clearInterval(this.scollMove);      //按鈕操作之前,先清除輪播定時器,避免時間衝突
            switch (type) {
                case "left": {
                    if (this.count === 0) {
                        this.count = (this.imgs.length - 1);
                    } else {
                        this.count--;
                    }
                    autoMove.styleMovement(this.count);
                    break;
                }
                case "right": {
                    autoMove.shiftMovement();
                    break;
                }
                default: {
                    this.count = type;
                    autoMove.styleMovement(type);
                    break
                }
            }
            this.scollMove = setInterval(function () {      //滑鼠操作完成後,重新執行輪播定時器
                autoMove.shiftMovement();
            }, 2000);
        },
        //事件綁定
        bindingEvent: function () {
            document.getElementById('btnleft').addEventListener("click", function () {       //給左按鈕綁定事件
                autoMove.btnAction("left");
            });
            document.getElementById('btnright').addEventListener("click", function () {      //給右按鈕綁定事件
                autoMove.btnAction("right");
            });
            document.querySelector('.item').addEventListener("click", function (event) {     //點擊某個具體span綁定事件
                autoMove.btnAction(parseInt(event.target.getAttribute("data-index")));
            });
        },
        //功能初始化:節點獲取,事件綁定,執行定時器
        init: function (par1,par2) {    //參數和功能初始化
            var tempImgs = this.imgs = document.getElementsByTagName(par1);
            var tempSpans = this.spans = document.getElementsByTagName(par2);
            var length = tempImgs.length;
            for (var i = length; i--;) {        //將所有img和span的opacity樣式都設置為0
                tempImgs[i].style.opacity = "0";
                tempSpans[i].style.background = "#ffffff";
            }
            autoMove.bindingEvent();
            autoMove.styleMovement(0);   //初始化時,顯示第一張圖片(索引為0的位置)
            this.count++;                //在執行輪播定時器之前,先將count計數自加 1,則在執行定時器時,圖片從第二張(索引為1)開始顯示,從而形成連貫顯示
            this.scollMove = setInterval(function () {   //設置輪播定時器,每2秒自動執行一次
                autoMove.shiftMovement()
            }, 2000)
        }
    };

    //載入完成執行
    window.onload = function () {
        autoMove.init("img", "span");
    };
</script>
</body>
</html>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 創建表時創建索引: 在已經存在的表上創建索引: 方法一 方法二 刪除索引: ...
  • 一、實驗素材: 附加學生信息表(student) 二、實驗要求: 1、 查詢student表中所有學生的信息 select * from student 2、 查詢student表中“姓名”“所在班級”和“成績”列內容 select 姓名,所在班級,成績 from student 3、 查詢stud ...
  • 當需要將一臺機器(源機器)上的一個資料庫完全複製到另一臺機器(目標機器)上時,可以選擇先在源機器上備份該資料庫,然後在目標機器上還原該備份的方法。 下麵詳細描述具體步驟: 1. 打開SQL server management studio 2. 連接到伺服器。在“伺服器名稱”上填寫本機名稱,可以在計 ...
  • last night,i've tested flashback by MyFlash tool,but failed,now let's do some other test with it.first of all,clear the test environment:drop the proc ...
  • 最近做了一個關於相冊的小App,需要對安卓手機的存儲設備進行讀取,首先需要獲取系統讀寫許可權,在網上一頓好找,對於老手來說,可能很容易,對於菜鳥來說,就有點困難了,為了容易學習,特把自己寫的一些心得寫下,用以參考。如有不當之處,歡迎指正。 首先做一個關於手機內部存儲和外部存儲之間的介紹: 對內部存儲設 ...
  • 1、標準廣播:是一種完全非同步執行的廣播,在廣播發出之後,所有的廣播接收器幾乎會在同一時刻接收到這條廣播信息,它們之間沒有先後順序。效率高、無法被截斷。 2、有序廣播:是一種同步執行的廣播,在廣播發出後,同一時刻只會有一個廣播接收器能夠接收到這條廣播,當這個廣播接收器中的邏輯執行完畢後,廣播才會繼續傳 ...
  • //1.var定義的變數可以修改,如果不初始化會輸出undefined,不會報錯。 var a; console.log(a); //undefined //2.let是塊級作用域,函數內部使用let定義後,對函數外部無影響。 let c = 3; console.log(c) function c... ...
  • 可參考 http://blog.pandax.me/cjbk/ 此文 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...