swiper 輪播中常用的效果,持續更新

来源:https://www.cnblogs.com/daniao11417/archive/2019/08/08/11322698.html
-Advertisement-
Play Games

swiper一款非常好用的輪播插件,支持移動端和PC端,用過很多次了,這次簡單的總結一下。方便以後查找使用,說明一下,下麵的例子是基於swiper 4.0+版本的,如果你是其他的版本,請自行前往官網查看 至於為什麼使用swiper,而不是自己手寫,請看下麵官網的截圖: 開個玩笑,說白了,就是這個確實 ...


  swiper一款非常好用的輪播插件,支持移動端和PC端,用過很多次了,這次簡單的總結一下。方便以後查找使用,說明一下,下麵的例子是基於swiper 4.0+版本的,如果你是其他的版本,請自行前往官網查看

至於為什麼使用swiper,而不是自己手寫,請看下麵官網的截圖:

開個玩笑,說白了,就是這個確實非常好用,而且很好上手,沒有什麼難度。而且裡面的API很友好,不像有的文檔,看起來很費勁,這個很清晰,好了,不說了,直接進入主題。

  1. 第一步肯定是引入他的css和js,它提供了cdn和下載引入兩種方式,由於我們現在的項目不是部署在國內,所以我就選擇了下載引入。
  2. 引入完成之後,就需要按照他的DOM結構引入里,這裡,需要註意的是,他的DOM結構是能滑動的骨架,有的class名字可以更改,但是有的是不能更改的。所以還是建議大家,建議他的DOM結果引入。簡單的說,就是三層DIV
 1 <div class="swiper-container">
 2     <div class="swiper-wrapper">
 3         <div class="swiper-slide">Slide 1</div>
 4         <div class="swiper-slide">Slide 2</div>
 5         <div class="swiper-slide">Slide 3</div>
 6     </div>
 7     <!-- 如果需要分頁器 -->
 8     <div class="swiper-pagination"></div>
 9     
10     <!-- 如果需要導航按鈕 -->
11     <div class="swiper-button-prev"></div>
12     <div class="swiper-button-next"></div>
13     
14     <!-- 如果需要滾動條 -->
15     <div class="swiper-scrollbar"></div>
16 </div>
17 導航等組件可以放在container之外

  3.初始化Swiper   這裡就是swiper的全部控制器了。這裡也是3.0和4.0最大不同的地方。(2.0我還真的沒有用過)

 1   var mySwiper = new Swiper ('.swiper-container', {
 2     direction: 'vertical', // 垂直切換選項
 3     loop: true, // 迴圈模式選項
 4     
 5     // 如果需要分頁器
 6     pagination: {
 7       el: '.swiper-pagination',
 8     },
 9     
10     // 如果需要前進後退按鈕
11     navigation: {
12       nextEl: '.swiper-button-next',
13       prevEl: '.swiper-button-prev',
14     },
15     
16     // 如果需要滾動條
17     scrollbar: {
18       el: '.swiper-scrollbar',
19     },
20   }) 

其實到這個時候,最簡單的一個swiper已經可以正常的運行了。但是這個畢竟是官網的例子,不是大家通用的, 所以在實際應用中,需要我們自己改造。

------------------------------------------------------------------------------華麗的分割線---------------------------------------------------------------------

下麵介紹一下,我自己的是怎麼應用的。請看下圖,就是簡單切換

本來是做的,點擊上面,切換兩個顯示,但是UI設計師要求,這個要像手機應用一樣滑動更換。所以這個時候就想到了swiper

首先應該是我的DOM文檔結構。請看下麵的截圖,為什麼是截圖,因為截圖的時候,我用編輯器把代碼摺疊了,這樣能更好的看到swiper的DOM結構

大家可以看到,上面的那個ul裡面,兩個選項是獨立的。而下麵的就是swiper中的標準文檔結構,其中兩個dl是我的頁面內容。這個時候,來初始化這個swiper,請看下麵的代碼

 1 var mySwiper = new Swiper('.swiper-container', {
 2         direction: 'horizontal', // 切換選項
 3         loop: false, // 迴圈模式選項     
 4         on: {
 5             slideChangeTransitionEnd: function () {
 6                 console.log(this.activeIndex); //切換結束時,告訴我現在是第幾個slide
 7                 var index = this.activeIndex;
 8                 $("#header li").removeClass("this_page").eq(index).addClass("this_page");
 9             },
10         },
11 
12     })

這裡比較不同的是,在第4行,加入了一個方法,請看官方的解釋:回調函數,swiper從一個slide過渡到另一個slide結束時執行。就是當我們滑動完成了,這裡會得到一個現在顯示的是第幾張的一個索引值,通過this.activeIndex來獲得,這個時候,我獲取到這個值以後,就可控制上面的li元素,添加自定義屬性,我這裡用到的選中的自定義屬性是this_page。當我給那個li添加上這個class名時,就能讓這一頁選中。這裡就實現了下麵控制上面了。但是這樣顯然是不完整的, 應該是一個雙向控制,點擊上面的li,也應該能控制下麵的滑動,所以就繼續尋找,找到了另一個方法。

1 $("#header li").click(function () {
2         var index = $(this).index();
3         $(this).siblings("li").removeClass("this_page");
4         $(this).addClass("this_page");
5         console.log(index);
6         mySwiper.slideTo(index);
7 })

及時slideTo(index)方法。請看官方的解釋:控制Swiper切換到指定slide。然後它裡面能傳輸三個參數,這三個參數的具體用法請看下麵你的表格

參數名類型是否必填描述
index num 必選 指定將要切換到的slide的索引
speed num 可選 切換速度(單位ms)
runCallbacks boolean 可選 設置為false時不會觸發transition回調函數

到此,我就實現了雙向控制,點擊上面的li能控制下麵的滑動,下麵的滑動,也能更改上面的選中。如果還有什麼問題,歡迎留言或者自行查看官網API文檔


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

-Advertisement-
Play Games
更多相關文章
  • 微信小程式支付功能的開發的時候坑比較多,不過對於錢的事謹慎也是好事。網上關於小程式支付的實例很多,但是大多多少有些問題,C#開發的更少。此篇文檔的目的是講開發過程中遇到的問題做一個備註,也方便其他開發的同學作為參考! 1、首先建議把官方文檔支付部分看上三遍,每個細節都不要放過,因為任何一個點和微信要 ...
  • This article documents the attempt to optimize the blog garden home page and the associated CSS source code. ...
  • JavaScript變數和作用域的學習筆記,包括變數的含義、作用,機制,以及作用域的機制、JS預解析等 ...
  • import axios from '@/libs/api.request' const MODULE_URL = '/log'; export const actionLogData = (params, cb) => { axios.request({ url: `${MODULE_URL}/a ...
  • jquerysessionjs插件使用介紹 by:授客 QQ:1033553122 JQuery-3.2.1.min.j 下載地址: https://gitee.com/ishouke/front_end_plugin/blob/master/jquery-3.2.1.min.js jqueryse ...
  • <form>元素: <input>元素: 常用屬性: type 文本框類型 name 指定了name的欄位才會被提交(不能用id代替name屬性) placeholder 占位符 value 輸入框中的文本 autofocus 自動聚焦 disabled 禁用 readonly 只讀 require ...
  • 一開始,我使用的是Jquery框架中的$.("#input").readOnly,發現取出的值為undefined,不知道是不是jQuery中不支持獲取標簽屬性的函數, 然後就使用了原生的document.getElementById("input1").readOnly並且可以更改它的值以及取值, ...
  • 寫在前面:前面的內容記錄了JavaScript的一些基本概念,本次主要講解一下JS中常用的語句。 和大多數其他編程語言一樣,JS也主要包括:選擇、迴圈、錯誤檢測、函數等。JS的語句基本是由值、運算符、表達式、關鍵字和註釋構成,但並不是語句一定包含所有以上要素。 電腦程式一般是指能夠被電腦執行的一 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...