vue仿攜程輪播圖效果(滑動(dòng)輪播,下方高度自適應(yīng))
先看案例,使用vue+swiper實(shí)現(xiàn),slide不同高度時(shí),動(dòng)態(tài)計(jì)算盒子高度,讓其下方高度自適應(yīng)的效果

首先搭建vue項(xiàng)目,這里不做過多說明,然后安裝swiper
npm install swiper --save-dev
1. js部分:初始化swiper組件,vue要在mounted生命周期中進(jìn)行初始化,代碼如下:
import Swiper from 'swiper'
import { TweenMax, Power2 } from 'gsap'

初始化時(shí)調(diào)用resize函數(shù),計(jì)算屏幕容器的寬高,代碼如下
// 重新計(jì)算屏幕寬高
resize(swiper) {
this.clientWidth = document.documentElement.clientWidth||document.body.clientWidth;
this.clientHeight = document.documentElement.clientHeight||document.body.clientHeight;
this.draw(swiper)
},
計(jì)算完后調(diào)用draw函數(shù),根據(jù)滑動(dòng)slide,動(dòng)態(tài)計(jì)算輪播容器的高度;注意這里引用了TweenMax框架,使用前需要安裝,詳細(xì)使用方法可參考官網(wǎng)TweenMax
npm install gsap -D
先大概看下TweenMax使用方法

// 動(dòng)態(tài)計(jì)算swiper-container高度
draw(swiper) {
TweenMax.to(this.tweenObj, 0.5, {translate: swiper.translate, ease: Power2.easeOut,
onUpdate: () => {
let translate = this.tweenObj.translate
// 左邊slide索引
let iLeft = Math.floor(-translate / this.clientWidth)
if (iLeft > this.slidesLength) {
iLeft = this.slidesLength
}
// 右邊slide索引
let iRight = iLeft + 1
if (iRight > this.slidesLength) {
iRight = this.slidesLength
}
for(let i=0; i< this.swiperSlide.length; i++){
//圖片寬度滿屏?xí)r,每個(gè)圖片的高度
this.swiperSlide[i].fullHeight = this.clientWidth/this.swiperSlide[i].getBoundingClientRect().width * this.swiperSlide[i].getBoundingClientRect().height;
}
//移動(dòng)比例 移動(dòng)過程中高度變化 0~1~0的變化規(guī)律
let percent = Number((-translate / this.clientWidth).toFixed(5)) - iLeft
//根據(jù)左右圖片和移動(dòng)比例得出相應(yīng)高度
let currentHeight = (this.swiperSlide[iRight].fullHeight - this.swiperSlide[iLeft].fullHeight )*percent + this.swiperSlide[iLeft].fullHeight
// 輪播容器高度
swiper.el.style.height = currentHeight +'px'
}
})
}
2.html部分
<!--仿攜程輪播效果-->
<div class="swiper-demo">
<div class="swiper-container">
<div class="swiper-wrapper">
<!--這里一定要加高度,不然會(huì)出問題?。。?->
<div class="swiper-slide" style="height: 222px;">
<div class="wrap" v-for="(item, index) in category1" :key="index">
<img src="../assets/wish.png" alt="">
<span>{{item.name}}</span>
</div>
</div>
<!--這里一定要加高度,不然會(huì)出問題!?。?->
<div class="swiper-slide" style="height: 400px;">
<div class="wrap" v-for="(item, index) in category2" :key="index">
<img src="../assets/wish.png" alt="">
<span>{{item.name}}</span>
</div>
</div>
</div>
</div>
<div style="background: salmon; height: 80vh">隨便寫自己的UI</div>
</div>
注意:swiper-slide一定要加高度,不然會(huì)出問題
3.css部分
.swiper-slide {
width: auto;
height: 100%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.wrap {
width: 24%;
height: 100px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
img {
width: 60px;
}
這樣就實(shí)現(xiàn)了一個(gè)高度自適應(yīng)的輪播效果了,三個(gè)及以上也沒問題啦,喜歡點(diǎn)個(gè)關(guān)注吧,嘻嘻~

到此這篇關(guān)于vue仿攜程輪播圖效果(滑動(dòng)輪播,下方高度自適應(yīng))的文章就介紹到這了,更多相關(guān)vue輪播圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue實(shí)現(xiàn)圖片輪播組件思路及實(shí)例解析
- vue不操作dom實(shí)現(xiàn)圖片輪播的示例代碼
- vue自定義js圖片碎片輪播圖切換效果的實(shí)現(xiàn)代碼
- 使用Vue制作圖片輪播組件思路詳解
- Vue封裝Swiper實(shí)現(xiàn)圖片輪播效果
- 利用Vue實(shí)現(xiàn)移動(dòng)端圖片輪播組件的方法實(shí)例
- 利用vueJs實(shí)現(xiàn)圖片輪播實(shí)例代碼
- VUE開發(fā)一個(gè)圖片輪播的組件示例代碼
- 基于vue.js實(shí)現(xiàn)圖片輪播效果
- vue實(shí)現(xiàn)自動(dòng)滑動(dòng)輪播圖片
相關(guān)文章
vant 時(shí)間選擇器--開始時(shí)間和結(jié)束時(shí)間實(shí)例
這篇文章主要介紹了vant 時(shí)間選擇器--開始時(shí)間和結(jié)束時(shí)間實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11
手動(dòng)實(shí)現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理詳解
這篇文章主要給大家介紹了關(guān)于手動(dòng)實(shí)現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Vue簡(jiǎn)明介紹配置對(duì)象的配置選項(xiàng)
我們知道每一個(gè)vue項(xiàng)目應(yīng)用都是通過vue的構(gòu)造函數(shù)進(jìn)行創(chuàng)建一個(gè)新的vue項(xiàng)目的。創(chuàng)建vue實(shí)例的配置對(duì)象,可以包括一下屬性選項(xiàng),比如:data、methods、watch、template等等,每一個(gè)選項(xiàng)都有不同的功能,大家可以根據(jù)自己的需求選擇不同的配置2022-08-08
webpack+vue-cli項(xiàng)目中引入外部非模塊格式j(luò)s的方法
今天小編就為大家分享一篇webpack+vue-cli項(xiàng)目中引入外部非模塊格式j(luò)s的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue.js的手腳架vue-cli項(xiàng)目搭建的步驟
這篇文章主要介紹了vue.js的手腳架vue-cli項(xiàng)目搭建的步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08

