多功能旋轉木馬輪播實例

来源:http://www.cnblogs.com/tie123abc/archive/2016/11/05/6032258.html
-Advertisement-
Play Games

今天項目需要用到旋轉木馬輪播功能,需要顯示個可以切換的選項,這幾個選項也許是圖片,也許是文字,也許是一個iframe頁面,也有可能是圖文混排,還可能需要支持調用介面數據,需要顯示多條信息,最少3條,最多不限,可能有10條,可能有10000條,於是就有了下麵這個實現方法,看上去已經很完美了(樣式和具體... ...


今天項目需要用到旋轉木馬輪播功能,需要顯示個可以切換的選項,這幾個選項也許是圖片,也許是文字,也許是一個iframe頁面,也有可能是圖文混排,還可能需要支持調用介面數據,需要顯示多條信息,最少3條,最多不限,可能有10條,可能有10000條,於是就有了下麵這個實現方法,看上去已經很完美了(樣式和具體顯示圖片、文字或者是iframe頁面、圖文混排、調用介面數據等請自行在此實例基礎上調試)

需要說明的是預先顯示:2   1   9,是因為一共有9張圖片,預設顯示第一張在中間,往右是2,背後那張是3,不過背後那張無需進行設置。這是視覺初始的效果,可根據自己需要調整。

 

carrousel.html

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>旋轉木馬輪播</title>
<style type="text/css">
html, body {
    width: 100%;
    height: 100%;
}
.carrousel .arrow_left {
    background: #000;
    left: 20px;
}
.carrousel .arrow_right {
    background: #000;
    right: 20px;
}
.carrousel .arrow_left, .carrousel .arrow_right {
    position: absolute;
    top: 50%;
    width: 50px;
    line-height: 50px;
    height: 50px;
    text-align: center;
    color: #FFF;
    cursor: pointer;
}
.carrousel .back {
    z-index: 1;
    opacity: 0.3;
    margin: auto;
    width: 10%;
    height: 60px;
    left: 45%;
}
.carrousel .left {
    left: 10%;
}
.carrousel .right {
    right: 10%;
}
.carrousel .left, .carrousel .right {
    top: 53%;
    width: 60px;
    height: 60px;
    z-index: 2;
    opacity: 0.5;
}
.carrousel .front {
    left: 45%;
    top: 50%;
    margin: auto;
    width: 10%;
    height: 100px;
    z-index: 3;
    opacity: 1;
}
.carrousel .front, .carrousel .right, .carrousel .back, .carrousel .left, .carrousel .content {
    position: absolute;
    background: #666;
    text-align: center;
    color: #FFF;
    font-size: 20px;
}
.carrousel .content {
    width: 100%;
    top: 80%;
    text-align: center;
    color: #fff;
    margin: auto;
}
</style>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.8.1.js"></script>
<script type="text/javascript">
//頁面載入完成後
$(document).ready(function(e) {

    //複製一個旋轉木馬輪播
    var a = carrousel;

    //初始化
    a.init($("#carrousel_a"), [
        ["1", "這是第一張圖或內容", "1.jpg"],
        ["2", "這是第二張圖或內容", "2.jpg"],
        ["3", "這是第三張圖或內容", "3.jpg"],
        ["4", "這是第四張圖或內容", "4.jpg"],
        ["5", "這是第五張圖或內容", "5.jpg"],
        ["6", "這是第六張圖或內容", "6.jpg"],
        ["7", "這是第七張圖或內容", "7.jpg"],
        ["8", "這是第八張圖或內容", "8.jpg"],
        ["9", "這是第九張圖或內容", "9.jpg"]
    ]);

    //左邊箭頭點擊
    $("#carrousel_a .arrow_left").click(function() {
        a.rotate("left");
    });

    //右邊箭頭點擊
    $("#carrousel_a .arrow_right").click(function() {
        a.rotate("right");
    });

});

/**
 * carrousel.js - v1.0.0 (2016-11-5)
 *
 * 旋轉木馬輪播
 * by tie. qq:2185987263
 *
 * Copyright (C) 2016, tie.
 * All rights reserved.
 *
 **/

var carrousel = {

    //>3~n
    data: [],

    obj: null,

    //初始化
    data_count: 0,
    init: function(obj, data) {

        var self = this;

        self.obj = obj;
        self.data = data;

        //左邊圖片計數器
        self.left_img_count = self.data.length - 1;

        //右邊圖片計數器
        self.right_img_count = 2;

        //數據計數器
        self.data_count = 0;

        //文字或圖片
        self.obj.find(".left").html(self.data[1][0]);
        //car_back的top一定要是最大得
        self.obj.find(".back").css({
            "top": self.obj.find(".left").offset().top + 1
        });
        self.obj.find(".right").html(self.data[self.left_img_count][0][0]);
        self.obj.find(".front").html(self.data[0][0]);
        self.obj.find(".content").html(self.data[0][1]);
    },

    //往左旋轉
    left_img_count: null,
    left_img_up: function() {

        var self = this;

        self.left_img_count--;
        if (self.left_img_count < 0) {
            self.left_img_count = self.data.length - 1;
        }

        var t, id;
        self.obj.find(".is_horse").each(function(i) {
            if (i > 0) {
                if ($(this).offset().top > t) {
                    id = $(this).attr("data-horse");
                    t = $(this).offset().top;
                }
            } else {
                id = $(this).attr("data-horse");
                t = $(this).offset().top;
            }
        });

        self.obj.find("." + id).html(self.data[self.left_img_count][0]);
        if (self.left_img_count <= 0) {
            self.left_img_count = self.data.length;
        }

        self.right_img_count--;
        if (self.right_img_count <= 0) {
            self.right_img_count = self.data.length;
        }

        self.show_content("left");

    },

    //往右旋轉
    right_img_count: null,
    right_img_up: function() {

        var self = this;

        self.left_img_count++;
        if (self.left_img_count >= self.data.length) {
            self.left_img_count = 0;
        }
        if (self.right_img_count >= self.data.length) {
            self.right_img_count = 0;
        }

        var t, id;
        self.obj.find(".is_horse").each(function(i) {
            if (i > 0) {
                if ($(this).offset().top > t) {
                    id = $(this).attr("data-horse");
                    t = $(this).offset().top;
                }
            } else {
                id = $(this).attr("data-horse");
                t = $(this).offset().top;
            }
        });

        self.obj.find("." + id).html(self.data[self.right_img_count][0]);

        self.right_img_count++;

        self.show_content("right");
    },

    //顯示內容
    show_content: function(direction) {

        var self = this;

        if (direction == "left") {
            self.data_count--;
            if (self.data_count < 0) {
                self.data_count = self.data.length - 1;
            }
        }

        if (direction == "right") {
            self.data_count++;
            if (self.data_count >= self.data.length) {
                self.data_count = 0;
            }
        }

        self.obj.find(".content").animate({
            opacity: 0
        }, 500, '', function() {
            self.obj.find(".content").html(self.data[self.data_count][1]).animate({
                opacity: 1
            }, 500);
        });
    },

    //旋轉
    direction_lock: false,
    rotate: function(direction) {

        var self = this;

        if (self.direction_lock) {
            return false;
        }
        self.direction_lock = true;

        var ol = self.obj.find(".left"),
            ob = self.obj.find(".back"),
            or = self.obj.find(".right"),
            of = self.obj.find(".front"),
            t1 = "opacity";
        t2 = "z-index";

        var l_l = ol.offset().left,
            l_t = ol.offset().top,
            l_w = ol.width(),
            l_h = ol.height(),
            l_o = ol.css(t1),
            l_z = ol.css(t2),

            r_l = or.offset().left,
            r_t = or.offset().top,
            r_w = or.width(),
            r_h = or.height(),
            r_o = or.css(t1),
            r_z = or.css(t2),

            b_l = ob.offset().left,
            b_t = ob.offset().top,
            b_w = ob.width(),
            b_h = ob.height(),
            b_o = ob.css(t1),
            b_z = ob.css(t2),

            f_l = of.offset().left,
            f_t = of.offset().top,
            f_w = of.width(),
            f_h = of.height(),
            f_o = of.css(t1),
            f_z = of.css(t2);

        var _l_l, _l_t, _l_w, _l_h, _r_l, _r_t, _r_w, _r_h, _b_l, _b_t, _b_w, _b_h, _f_l, _f_t, _f_w, _f_h;

        if (direction == "left") {
            self.left_img_up();
            _f_l = l_l, _f_t = l_t, _f_w = l_w, _f_h = l_h, _f_o = l_o, _f_z = l_z;
            _b_l = r_l, _b_t = r_t, _b_w = r_w, _b_h = r_h, _b_o = r_o, _b_z = r_z;
            _r_l = f_l, _r_t = f_t, _r_w = f_w, _r_h = f_h, _r_o = f_o, _r_z = f_z;
            _l_l = b_l, _l_t = b_t, _l_w = b_w, _l_h = b_h, _l_o = b_o, _l_z = b_z;
        }
        if (direction == 
              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 總結一下自己在寫這個需求遇到的問題,相信大家應該是經常遇到的。即要求滾輪滾動到指定的位置。先看下基本的解決方案。 1.給鏈接a加個#的方式來實現跳轉。(錨點方法)這裡直接貼下代碼: html頁面: css樣式: 該錨點法,不需要任何的js代碼,即可實現跳轉的方法。缺點:點擊鏈接url發生變化,刷新的 ...
  • 一、Redux介紹 Redux的設計思想很簡單,就兩句話: 二、Redux基本概念和API Store Store就是保存數據(state)的地方,整個應用只能有一個Store。Redux通過createStore來生成store。 State Store對象包含所有State,某一時刻的數據集合就 ...
  • 在WebGL場景中導入多個Babylon骨骼模型,在區域網用WebSocket實現多用戶交互控制。 ...
  • 時光轉眼即逝,又到周六了,今天寫點某部分人看不起的css玩玩! 轉換 轉換屬性transform: 瀏覽器首碼: -webkit-transform;-o-transform;-moz-transform;-ms-transform; 取值: none : 預設值,沒有轉換操作 transform- ...
  • 1、操作元素之屬性: ①attr讀:$(“selector”).attr(“屬性名”);=>getAttribute(“屬性名”);改:$(“selector”).attr(“屬性名”,值);=>setAttribute(“屬性名”,值);*(*無法訪問不再開始標簽中存在的prop屬性;例:chec ...
  • 很多人會用sort(),並不見得知道它具體是怎樣給數字排序的。其實不知道也行,會用就可以,感興趣的可以來看看。 用過sort()函數的都知道上面代碼其實就是將數組裡的元素從小到大排序,返回結果[1,2,3,4]。 為了弄清楚sort()是怎樣進行數字比較和移動,最後排好序的,我加三行代碼,讓它把每一 ...
  • var EventHandle = { addEvent:function(ele,type,handle){ if (ele.addEventListener) { ele.addEventListener(type,handle,false); }else if(attachEvent){ el ...
  • html部分 <!DOCTYPE html> <!--下麵三個百分比都是為了實現後期項目優化的時候,實現自適應屏幕的寬度和高度--> <html style="height: 100%;"> <!--這個需要HTML標簽上也得加上style="height:100%"才行,要不然會顯示一半,經常用C ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...