欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue封裝Swiper實(shí)現(xiàn)圖片輪播效果

 更新時(shí)間:2018年02月06日 15:46:51   投稿:mrr  
圖片輪播是前端中經(jīng)常需要實(shí)現(xiàn)的一個(gè)功能。最近學(xué)習(xí)Vue.js,就針對Swiper進(jìn)行封裝,實(shí)現(xiàn)一個(gè)簡單的圖片輪播組件。感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧

圖片輪播是前端中經(jīng)常需要實(shí)現(xiàn)的一個(gè)功能。最近學(xué)習(xí)Vue.js,就針對Swiper進(jìn)行封裝,實(shí)現(xiàn)一個(gè)簡單的圖片輪播組件。

一、Swiper

在實(shí)現(xiàn)封裝之前,先介紹一下Swiper。

  • Swiper是純Javascript打造的滑動(dòng)特效插件,面向手機(jī)、平板電腦等移動(dòng)終端。
  • Swiper能實(shí)現(xiàn)觸屏焦點(diǎn)圖、觸屏Tab切換、觸屏多圖切換等常用效果。
  • Swiper開源、免費(fèi)、穩(wěn)定、使用簡單、功能強(qiáng)大,是架構(gòu)移動(dòng)終端網(wǎng)站的重要選擇。

Swiper的應(yīng)用場景廣泛,實(shí)現(xiàn)效果很好,下面?zhèn)€這實(shí)際案例就是Swiper的典型應(yīng)用場景。

 

Swiper的具體使用教程及詳細(xì)API,參考 Swiper中文網(wǎng)
。

二、Vue組件

Vue組件設(shè)計(jì)初衷就是要配合使用的,提高維護(hù)性和復(fù)用性。而圖片輪播正適合使用組件來完成,因此在介紹具體的實(shí)現(xiàn)之前,先介紹下關(guān)于Vue組件及組件通信。

Vue組件中最常見的就是形成父子組件的關(guān)系:組件 A 在它的模板中使用了組件 B。

它們之間必然需要相互通信:父組件可能要給子組件下發(fā)數(shù)據(jù),子組件則可能要將它內(nèi)部發(fā)生的事情告知父組件。然而,通過一個(gè)良好定義的接口來盡可能將父子組件解耦也是很重要的。這保證了每個(gè)組件的代碼可以在相對隔離的環(huán)境中書寫和理解,從而提高了其可維護(hù)性和復(fù)用性。

在 Vue 中,父子組件的關(guān)系可以總結(jié)為 prop 向下傳遞,事件向上傳遞。父組件通過 prop 給子組件下發(fā)數(shù)據(jù),子組件通過事件給父組件發(fā)送消息。

 

三、封裝實(shí)現(xiàn)

1.引入Swiper

首先,需要安裝Swiper。

npm install --save swiper

然后,要引用兩個(gè)文件。

import Swiper from "swiper";
import "swiper/dist/css/swiper.min.css";


2.HTML代碼

在模板中設(shè)置輪播圖的html布局。

<template>
 <div class="swiper-container" :class="swipeid">
  <div class="swiper-wrapper">
   <!-- 存放具體的輪播內(nèi)容 -->
   <slot name ="swiper-con"></slot>
  </div>
  <!-- 分頁器 -->
  <div :class="{'swiper-pagination':pagination}"></div>
 </div>
</template>

其中使用具名插槽,提高解耦,使得在父組件使用時(shí),根據(jù)不同情況,設(shè)置不同的輪播內(nèi)容。

另外需要設(shè)置分頁器,即圖片輪播中的頁面指示器,常見的如小圓點(diǎn),或者數(shù)字指示器。

3.初始化Swiper

既然是對Swiper進(jìn)行封裝實(shí)現(xiàn)輪播圖,前面也已經(jīng)安裝了Swiper,那么現(xiàn)在就需要初始化使用。

在初始化之前,根據(jù)Swiper用法的了解,先確定輪播組件需要的屬性信息,然后通過父組件傳遞給封裝的Swiper組件。

這時(shí)候就需要用到props。

props: {
 swipeid: {
  type: String,
  default: ""
 },
 effect: {
  type: String,
  default: "slide"
 },
 loop: {
  type: Boolean,
  default: false
 },
 direction: {
  type: String,
  default: "horizontal"
 },
 pagination: {
  type: Boolean,
  default: true
 },
 paginationType: {
  type: String,
  default: "bullets"
 },
 autoPlay: {
  type: Number,
  default: 3000
 }
 }

下面逐一解釋每個(gè)屬性的含義。

屬性 含義
swiped 輪播容器class屬性的類名。
effect 圖片的 切換效果,默認(rèn)為"slide",還可設(shè)置為"fade", "cube", "coverflow","flip",詳情見effect。
loop 設(shè)置為true 則開啟loop模式。loop模式:會在原本圖片前后復(fù)制若干個(gè)圖片并在合適的時(shí)候切換,讓Swiper看起來是循環(huán)的,詳情見loop。
direction 圖片的滑動(dòng)方向,可設(shè)置水平(horizontal)或垂直(vertical),詳情見direction。
pagination 使用分頁導(dǎo)航,詳情見pagination。
paginationType 分頁器樣式類型,可設(shè)置為"bullets", "fraction", "progressbar", "custom",詳情見type。
autoPlay 設(shè)置為true啟動(dòng)自動(dòng)切換,并使用默認(rèn)的切換設(shè)置,詳情見autoplay。

了解了上面每個(gè)屬性的含義,下面就可以初始化Swiper,并設(shè)置具體的屬性。

初始化Swiper時(shí),需要傳入兩個(gè)參數(shù)。

  • 輪播容器的類名
  • 代表圖片輪播組件詳細(xì)功能的對象
var that = this;
 this.dom = new Swiper("." + that.swipeid, {
  //循環(huán)
  loop: that.loop,
  //分頁器
  pagination: { 
  el: ".swiper-pagination",
  bulletClass : 'swiper-pagination-bullet',
   },
  //分頁類型
  paginationType: that.paginationType,
  //自動(dòng)播放
  autoPlay: that.autoPlay,
  //方向
  direction: that.direction,
  //特效
  effect: that.effect,
  //用戶操作swiper之后,不禁止autoplay
  disableOnInteraction: false,
  //修改swiper自己或子元素時(shí),自動(dòng)初始化swiper
  observer: true,
  //修改swiper的父元素時(shí),自動(dòng)初始化swiper
  observeParents: true
 });
 }

四、自定義輪播效果

經(jīng)過上面的步驟,輪播器就封裝好了。我們可以自定義實(shí)現(xiàn)自己想要的輪播器效果。下面以知乎的API為例,實(shí)現(xiàn)圖片輪播。

1.HTML代碼

<m-swipe swipeid="swipe" ref="swiper" :autoPlay="3000" effect="slide">
  <div v-for="top in tops" :key="top.id" class="swiper-slide" slot="swiper-con" >
  <img :src="top.image">
  <h3>{{top.title}}</h3>
  </div>
</m-swipe>

首先要引用注冊組件,這里就不詳細(xì)寫出。

其中 m-swipe 就是前面實(shí)現(xiàn)的圖片輪播組件,而其中的子組件就是通過具名插槽插入的輪播內(nèi)容。

2.CSS代碼

.swiper-container {
 width: 100%;
 }
 .swiper-slide {
 height: 8rem;
 overflow: hidden;
 position: relative;
 }
.swiper-slide {
 div {
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
 opacity: 0.4;
 position: absolute;
 background-color: @blue;
 }
 img {
 top: 50%;
 position: relative;
 transform: translate(0, -50%);
 }
 h3 {
 width: 70%;
 color: #fff;
 margin: 0;
 font-size: 0.5rem;
 line-height: 1rem;
 right: 5%;
 bottom: 2.6rem;
 text-align: right;
 position: absolute;
 text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.5);
 &:before {
  content: "";
  width: 3rem;
  bottom: -0.6rem;
  right: 0;
  display: block;
  position: absolute;
  border: 2px solid @yellow;
 }
 }
}
.swiper-pagination-bullet-active {
 background: #fff;
}
.swiper-container-horizontal > .swiper-pagination-bullets {
 bottom: 1rem;
 width: 95%;
 text-align: right;
 }

其中 swiper-pagination-bullet-active 代表分頁器中當(dāng)前指示的小圓點(diǎn)的類名。 .swiper-pagination-bullets 代表分頁器的類名,詳情見pagination分頁器內(nèi)元素的類名 。

關(guān)于網(wǎng)絡(luò)請求數(shù)據(jù)展示的代碼就不貼了,下面有源碼地址。

3.效果

 

這只是一個(gè)簡單的封裝效果,想要實(shí)現(xiàn)更多的效果,可以通過Swiper中提供的更多功能來實(shí)現(xiàn)。

Github地址: 圖片輪播

總結(jié)

以上所述是小編給大家介紹的Vue封裝Swiper實(shí)現(xiàn)圖片輪播效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 詳解如何在Vue項(xiàng)目中發(fā)送jsonp請求

    詳解如何在Vue項(xiàng)目中發(fā)送jsonp請求

    這篇文章主要介紹了詳解如何在Vue項(xiàng)目中發(fā)送jsonp請求,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vue.js創(chuàng)建Calendar日歷效果

    Vue.js創(chuàng)建Calendar日歷效果

    這篇文章主要為大家詳細(xì)介紹了Vue.js創(chuàng)建Calendar日歷效果的過程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Vue預(yù)渲染:prerender-spa-plugin生成靜態(tài)HTML與vue-meta-info更新meta

    Vue預(yù)渲染:prerender-spa-plugin生成靜態(tài)HTML與vue-meta-info更新meta

    Vue.js中,prerender-spa-plugin和vue-meta-info插件的結(jié)合使用,提供了解決SEO問題的方案,prerender-spa-plugin通過預(yù)渲染技術(shù)生成靜態(tài)HTML,而vue-meta-info則能動(dòng)態(tài)管理頁面元數(shù)據(jù),本文將探討如何使用這兩個(gè)工具優(yōu)化Vue.js項(xiàng)目的SEO表現(xiàn),包括安裝、配置及注意事項(xiàng)
    2024-10-10
  • elementui源碼學(xué)習(xí)仿寫el-link示例詳解

    elementui源碼學(xué)習(xí)仿寫el-link示例詳解

    這篇文章主要為大家介紹了elementui源碼學(xué)習(xí)仿寫el-link示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Vue2.x中的Render函數(shù)詳解

    Vue2.x中的Render函數(shù)詳解

    通常開發(fā)vue我們使用的是模板語法,其實(shí)還有和react相同的語法,那就是render函數(shù),同樣支持jsx語法。Vue 的模板實(shí)際是編譯成了 render 函數(shù)。
    2017-05-05
  • vue下拉刷新組件的開發(fā)及slot的使用詳解

    vue下拉刷新組件的開發(fā)及slot的使用詳解

    這篇文章主要介紹了vue下拉刷新組件的開發(fā)及slot的使用詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • vue基于element-ui的三級CheckBox復(fù)選框功能的實(shí)現(xiàn)代碼

    vue基于element-ui的三級CheckBox復(fù)選框功能的實(shí)現(xiàn)代碼

    最近vue項(xiàng)目需要用到三級CheckBox復(fù)選框,需要實(shí)現(xiàn)全選反選不確定三種狀態(tài)。這篇文章主要介紹了vue基于element-ui的三級CheckBox復(fù)選框功能的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2018-10-10
  • vue2.0實(shí)現(xiàn)前端星星評分功能組件實(shí)例代碼

    vue2.0實(shí)現(xiàn)前端星星評分功能組件實(shí)例代碼

    本文通過實(shí)例代碼給大家介紹了vue2.0實(shí)現(xiàn)前端星星評分功能組件,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2018-02-02
  • vue踩坑之backgroundImage路徑問題及解決

    vue踩坑之backgroundImage路徑問題及解決

    這篇文章主要介紹了vue踩坑之backgroundImage路徑問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析

    vue2路由方式--嵌套路由實(shí)現(xiàn)方法分析

    這篇文章主要介紹了vue2嵌套路由實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了vue2嵌套路由基本實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03

最新評論