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

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

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

先看案例,使用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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

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

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

    簡(jiǎn)單說說如何使用vue-router插件的方法

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

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

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

    一篇文章教會(huì)你部署vue項(xiàng)目到docker

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

    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é)

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

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

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

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

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

    vue自定義封裝按鈕組件

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

最新評(píng)論