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

vue仿攜程輪播圖效果(滑動輪播,下方高度自適應)

 更新時間:2021年02月11日 10:00:42   作者:牛頓頓的apple  
這篇文章主要介紹了vue仿攜程輪播圖效果(滑動輪播,下方高度自適應),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

先看案例,使用vue+swiper實現(xiàn),slide不同高度時,動態(tài)計算盒子高度,讓其下方高度自適應的效果

在這里插入圖片描述

首先搭建vue項目,這里不做過多說明,然后安裝swiper

npm install swiper --save-dev

1. js部分:初始化swiper組件,vue要在mounted生命周期中進行初始化,代碼如下:

import Swiper from 'swiper'
import { TweenMax, Power2 } from 'gsap'

在這里插入圖片描述

初始化時調(diào)用resize函數(shù),計算屏幕容器的寬高,代碼如下

// 重新計算屏幕寬高
resize(swiper) {
	this.clientWidth = document.documentElement.clientWidth||document.body.clientWidth;
	this.clientHeight = document.documentElement.clientHeight||document.body.clientHeight;
	this.draw(swiper)
},

計算完后調(diào)用draw函數(shù),根據(jù)滑動slide,動態(tài)計算輪播容器的高度;注意這里引用了TweenMax框架,使用前需要安裝,詳細使用方法可參考官網(wǎng)TweenMax

npm install gsap -D

先大概看下TweenMax使用方法

在這里插入圖片描述

// 動態(tài)計算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++){
							//圖片寬度滿屏時,每個圖片的高度
							this.swiperSlide[i].fullHeight = this.clientWidth/this.swiperSlide[i].getBoundingClientRect().width * this.swiperSlide[i].getBoundingClientRect().height;
						}
						//移動比例 移動過程中高度變化 0~1~0的變化規(guī)律
						let percent = Number((-translate / this.clientWidth).toFixed(5)) - iLeft
						//根據(jù)左右圖片和移動比例得出相應高度
						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">
			<!--這里一定要加高度,不然會出問題?。?!-->
				<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>
					<!--這里一定要加高度,不然會出問題!?。?->
				<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一定要加高度,不然會出問題

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;
	}

這樣就實現(xiàn)了一個高度自適應的輪播效果了,三個及以上也沒問題啦,喜歡點個關注吧,嘻嘻~

在這里插入圖片描述

到此這篇關于vue仿攜程輪播圖效果(滑動輪播,下方高度自適應)的文章就介紹到這了,更多相關vue輪播圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue中的Ajax?配置代理slot插槽的方法詳解

    Vue中的Ajax?配置代理slot插槽的方法詳解

    這篇文章主要介紹了Vue中的Ajax?配置代理?slot插槽的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 簡單說說如何使用vue-router插件的方法

    簡單說說如何使用vue-router插件的方法

    這篇文章主要介紹了如何使用vue-router插件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • VUE3函數(shù)的聲明和使用舉例

    VUE3函數(shù)的聲明和使用舉例

    這篇文章主要給大家介紹了關于VUE3函數(shù)的聲明和使用的相關資料, Vue3是一種流行的JavaScript框架,它允許開發(fā)人員構(gòu)建現(xiàn)代化的Web應用程序,需要的朋友可以參考下
    2023-07-07
  • Vue+Vuex實現(xiàn)自動登錄的知識點詳解

    Vue+Vuex實現(xiàn)自動登錄的知識點詳解

    在本篇文章里小編給大家整理的是關于Vue+Vuex實現(xiàn)自動登錄的知識點詳解,需要的朋友們可以學習下。
    2020-03-03
  • 一篇文章教會你部署vue項目到docker

    一篇文章教會你部署vue項目到docker

    在前端開發(fā)中,部署項目是我們經(jīng)常發(fā)生的事情,下面這篇文章主要給大家介紹了關于部署vue項目到docker的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • vue實現(xiàn)前端展示后端實時日志帶顏色示例詳解

    vue實現(xiàn)前端展示后端實時日志帶顏色示例詳解

    這篇文章主要為大家介紹了vue實現(xiàn)前端展示后端實時日志帶顏色示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 關于vue中輸入框的使用場景總結(jié)

    關于vue中輸入框的使用場景總結(jié)

    這篇文章主要介紹了關于vue中輸入框的使用場景總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue+vux?vux安裝出現(xiàn)錯誤問題及解決

    vue+vux?vux安裝出現(xiàn)錯誤問題及解決

    這篇文章主要介紹了vue+vux?vux安裝出現(xiàn)錯誤問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue?插槽?Slots源碼解析與用法詳解

    Vue?插槽?Slots源碼解析與用法詳解

    這篇文章主要介紹了Vue?插槽?(Slots)?源碼解析與用法,通過實例,我們?nèi)媪私饬四J插槽、具名插槽和作用域插槽的用法,并深入理解了其在Vue源碼中的實現(xiàn)原理,需要的朋友可以參考下
    2024-01-01
  • vue自定義封裝按鈕組件

    vue自定義封裝按鈕組件

    這篇文章主要為大家詳細介紹了vue自定義封裝按鈕組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論