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

首先搭建vue項(xiàng)目,這里不做過(guò)多說(shuō)明,然后安裝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)過(guò)程中高度變化 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ì)出問(wèn)題?。?!-->
<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ì)出問(wèn)題?。?!-->
<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">隨便寫(xiě)自己的UI</div>
</div>
注意:swiper-slide一定要加高度,不然會(huì)出問(wèn)題
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è)及以上也沒(méi)問(wèn)題啦,喜歡點(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開(kāi)發(fā)一個(gè)圖片輪播的組件示例代碼
- 基于vue.js實(shí)現(xiàn)圖片輪播效果
- vue實(shí)現(xiàn)自動(dòng)滑動(dòng)輪播圖片
相關(guān)文章
簡(jiǎn)單說(shuō)說(shuō)如何使用vue-router插件的方法
這篇文章主要介紹了如何使用vue-router插件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Vue+Vuex實(shí)現(xiàn)自動(dòng)登錄的知識(shí)點(diǎn)詳解
在本篇文章里小編給大家整理的是關(guān)于Vue+Vuex實(shí)現(xiàn)自動(dòng)登錄的知識(shí)點(diǎn)詳解,需要的朋友們可以學(xué)習(xí)下。2020-03-03
一篇文章教會(huì)你部署vue項(xiàng)目到docker
在前端開(kāi)發(fā)中,部署項(xiàng)目是我們經(jīng)常發(fā)生的事情,下面這篇文章主要給大家介紹了關(guān)于部署vue項(xiàng)目到docker的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
vue實(shí)現(xiàn)前端展示后端實(shí)時(shí)日志帶顏色示例詳解
這篇文章主要為大家介紹了vue實(shí)現(xiàn)前端展示后端實(shí)時(shí)日志帶顏色示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
關(guān)于vue中輸入框的使用場(chǎng)景總結(jié)
這篇文章主要介紹了關(guān)于vue中輸入框的使用場(chǎng)景總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05
vue+vux?vux安裝出現(xiàn)錯(cuò)誤問(wèn)題及解決
這篇文章主要介紹了vue+vux?vux安裝出現(xiàn)錯(cuò)誤問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08

