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)文章
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
在前端開發(fā)中,部署項(xiàng)目是我們經(jīng)常發(fā)生的事情,下面這篇文章主要給大家介紹了關(guān)于部署vue項(xiàng)目到docker的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04vue實(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-05vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決
這篇文章主要介紹了vue+vux?vux安裝出現(xiàn)錯(cuò)誤問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08