溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

發(fā)布時間:2021-04-23 12:29:59 來源:億速云 閱讀:680 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

vue是什么

Vue是一套用于構(gòu)建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫只關(guān)注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫開發(fā)復(fù)雜的單頁應(yīng)用。

vue-awesome-swiper就是其中一個前輩們產(chǎn)出的結(jié)晶。就看首尾兩個單詞,就知道他是vue和swiper的愛情之子了。

vue-awesome-swiper官網(wǎng)是中文文檔,媽媽再也不用擔心我讀api啦?!盎?Swiper4、適用于 Vue 的輪播組件”。在產(chǎn)品催著進度的緊張環(huán)境下,在四處搜尋解決方案的情況下,這句話簡直發(fā)著光啊。

具體怎么用,官方文檔寫的很清楚,但我還是想記錄下來,好再普及一波。

一、天才第一步,這里沒有紙尿褲((⊙﹏⊙) 好像暴露了年齡...)

準備一個基于vue-cli的項目(或者你自己的腳手架,whatever),沒有準備的請移駕vue-cli教程:

https://www.jb51.net/article/150412.htm

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

二、在項目目錄下,往node_modules里安裝插件vue-awesome-swiper(可以在項目目錄內(nèi),shift+鼠標右鍵,選擇"在此處打開命令窗口"),

 vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

注釋:我這里window電腦安裝了,所有右鍵出現(xiàn)的可能和沒安裝的不一樣,實在找不到的看這一篇教程:gulp安裝流程、使用方法及CMD常用命令導(dǎo)覽

然后輸入下邊的安裝插件命令

npm i --s vue-awesome-swiper

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

三、第三步我們依舊沒有天才牌褲子,所以還是自己一步一步穩(wěn)穩(wěn)走。

1.插件安裝后就是引用插件了,main.js內(nèi)部分三步走:

(1) 引用插件:mainjs注冊vas

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(2) 注冊插件

注冊后未use控制臺就警告了

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

通過全局方法 Vue.use() 使用插件后可以了

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

使用后控制臺無錯了

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(3) 插件樣式(也可以自己寫,不用人家的)

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

2.vue項目中使用:

(1) 準備-template

new a project準備一個空項目

 vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

初始化html-空結(jié)構(gòu)

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(2) 引入-import

 vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(3) 注冊組件-components

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(4) 配置-js(具體配置和swiper的一摸一樣,看swiper官網(wǎng)即可。我這里只說下我本次使用的配置的含義)

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

swiper官網(wǎng)參數(shù)

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

(5)美化- css

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

wan~

效果:

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果

代碼:

main.js

import VueAwesomeSwiper from 'vue-awesome-swiper'
import 'swiper/dist/css/swiper.css'
Vue.use(VueAwesomeSwiper)

zujian.vue

<template>
 <div class="hello-world">
 <!-- <h4>https://github.com/surmon-china/vue-awesome-swiper</h4> -->
 <!-- <h4>http://www.swiper.com.cn/api/index2.html</h4> -->
 <!-- http://www.swiper.com.cn/api/parameters/21.html -->
 <transition name="fade">
 <swiper id="swiperBox" v-bind:options="swiperOption" ref="mySwiper">
 <!-- 第一頁 -->
 <swiper-slide class="swiper-slide1">
 <div class="page">
 <h4>第一頁</h4>
 </div>
 </swiper-slide>
 <!-- 第二頁 -->
 <swiper-slide class="swiper-slide2">
 <div class="page">
 <h4>第二頁</h4>
 </div>
 </swiper-slide>
 <!-- 第三頁 -->
 <swiper-slide class="swiper-slide3">
 <div class="page">
 <h4>第三頁</h4>
 </div>
 </swiper-slide>
 </swiper>
 </transition>
 </div>
</template>
<script>
import { swiper, swiperSlide } from 'vue-awesome-swiper'
export default {
 name: 'HelloWorld',
 components: {
 swiper,
 swiperSlide
 },
 data () {
 return {
 swiperOption: {
 // swiper configs 所有的配置同swiper官方api配置
 notNextTick: true,//notNextTick是一個組件自有屬性,如果notNextTick設(shè)置為true,組件則不會通過NextTick來實例化swiper,也就意味著你可以在第一時間獲取到swiper對象,假如你需要剛加載遍使用獲取swiper對象來做什么事,那么這個屬性一定要是true
 direction: 'vertical',//水平方向移動
 grabCursor: true,//鼠標覆蓋Swiper時指針會變成手掌形狀,拖動時指針會變成抓手形狀
 setWrapperSize: true,//Swiper使用flexbox布局(display: flex),開啟這個設(shè)定會在Wrapper上添加等于slides相加的寬或高,在對flexbox布局的支持不是很好的瀏覽器中可能需要用到。
 autoHeight: true,//自動高度。設(shè)置為true時,wrapper和container會隨著當前slide的高度而發(fā)生變化
 slidesPerView: 1,//設(shè)置slider容器能夠同時顯示的slides數(shù)量(carousel模式)??梢栽O(shè)置為數(shù)字(可為小數(shù),小數(shù)不可loop),或者 'auto'則自動根據(jù)slides的寬度來設(shè)定數(shù)量。loop模式下如果設(shè)置為'auto'還需要設(shè)置另外一個參數(shù)loopedSlides。
 mousewheel: false,//開啟鼠標滾輪控制Swiper切換。可設(shè)置鼠標選項,默認值false
 mousewheelControl: false,//同上
 height: window.innerHeight, // 高度設(shè)置,占滿設(shè)備高度
 resistanceRatio: 0,//抵抗率。邊緣抵抗力的大小比例。值越小抵抗越大越難將slide拖離邊緣,0時完全無法拖離。本業(yè)務(wù)需要
 observeParents: true,//將observe應(yīng)用于Swiper的父元素。當Swiper的父元素變化時,例如window.resize,Swiper更新
 // 如果自行設(shè)計了插件,那么插件的一些配置相關(guān)參數(shù),也應(yīng)該出現(xiàn)在這個對象中,如下debugger
 debugger: true,
 // swiper的各種回調(diào)函數(shù)也可以出現(xiàn)在這個對象中,和swiper官方一樣
 onTransitionStart(swiper){
 console.log(swiper)
 }
 }
 },
 computed: {
 swiper() {
 return this.$refs.mySwiper.swiper
 }
 },
 mounted() {
 // current swiper instance
 // 然后你就可以使用當前上下文內(nèi)的swiper對象去做你想做的事了
 console.log('this is current swiper instance object', this.swiper)
 this.swiper.slideTo(3, 1000, false)
 }
}
</script>
<style scoped>
 .fade-enter-active, .fade-leave-active {
 transition: opacity .5s
 }
 .fade-enter, .fade-leave-to{
 opacity: 0
 }
 .swiper-wrapper{
 height: 100px;
 }
 .swiper-slide1{
 background: skyblue;
 }
 .swiper-slide2{
 background: yellowgreen;
 }
 .swiper-slide3{
 background: blanchedalmond;
 }
</style>

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vue-awesome-swiper怎么基于vue實現(xiàn)h5滑動翻頁效果”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI