vue項(xiàng)目中swiper輪播active圖片實(shí)現(xiàn)居中并放大
swiper輪播active圖片實(shí)現(xiàn)居中并放大
項(xiàng)目中用的是vue-awesome-swiper,vue-awesome-swiper是基于swiper 4.0的。所以參數(shù)參考swiper 4.0。
使用場(chǎng)景如下
要求左右切換時(shí)每次只移動(dòng)一個(gè)圖片,中間的圖片始終放大,其他圖片有不透明度。
解決思路
在官方文檔中,active slide默認(rèn)是居左的,通過把centeredSlides設(shè)置為true可以使其居中,但是左邊會(huì)空著。
解決思路就是,在第一張時(shí)候手動(dòng)去設(shè)置位移的距離。
代碼如下
template部分:
<div class="swiper-father swiper-hot"> <swiper :options="swiperOption" ref="mySwiper" v-if="homeData[5]"> <swiper-slide v-for='(item,index) in homeData[5]' :key="index"> <img @click="goInto(item.id)" :src="item.imgUrl"> </swiper-slide> </swiper> <div class="swiper-button-prev btn-swiper swiper-button" slot="button-prev"></div> <div class="swiper-button-next btn-swiper swiper-button" slot="button-next"></div> </div>
data部分:
data() { swiperOption: { slidesPerView: 3, // 顯示數(shù)量 centeredSlides:true, // 重點(diǎn):讓active slide居中 loop : true, //循環(huán)輪播 navigation: { // 左右按鈕 nextEl: '.swiper-button-next', prevEl: '.swiper-button-prev' }, on:{ init(){ this.setTranslate(0); }, transitionStart(){ // 開始translate之前觸發(fā) // 如果是第一張 if(this.activeIndex == 0){ this.setTranslate(0); // 因?yàn)樽筮厱?huì)空出一張圖的距離,所以設(shè)置位移為0 } }, } }
swiper輪播—異形輪播
最近經(jīng)常會(huì)碰到很多用swiper插件做各種各樣輪播圖的需求,沒有做過3d異形輪播圖,所以研究了一下,把經(jīng)驗(yàn)給大家分享一下
上面圖片就是輪播圖所要達(dá)到的效果:焦點(diǎn)圖片居中并向前突出,自動(dòng)輪播。
代碼介紹:
1.我的移動(dòng)端屏幕尺寸640px,這個(gè)移動(dòng)端屏幕適應(yīng)是封裝好的,如果需要引用,只需要改一下屏幕尺寸就好了。
2.我的圖片大小是251*441。
3.swiper:指滑動(dòng)、切換(整個(gè)滑動(dòng)對(duì)象,有時(shí)特指滑塊釋放后仍然正向移動(dòng)直到貼合邊緣的過程(過渡))
container
:指容器(swiper的容器里面包括滑動(dòng)快(slide)的集合(wrapper)、分頁(yè)器(pagination)、前進(jìn)按鈕等)wrapper
:指包含(觸控的對(duì)象,可觸摸區(qū)域,移動(dòng)的塊的集合,過渡時(shí)會(huì)隨slide切換產(chǎn)生位移)slider
:指滑塊(切換的塊中的一個(gè),可以包含文字、圖片、html元素或另外一個(gè)swiperpagination
:指分頁(yè)器(指示slide的數(shù)量和當(dāng)前活動(dòng)的slide)active
:指活動(dòng)的,激活的(可視的(visible)slide是活動(dòng)的,當(dāng)可視slide不止一個(gè)時(shí),默認(rèn)最左邊那個(gè)活動(dòng)的)
4.詳細(xì)參數(shù)配置參照swiper配置
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <link rel="stylesheet" rel="external nofollow" > <script> //屏幕適應(yīng) --移動(dòng)端 (function (win, doc) { if (!win.addEventListener) return; var html = document.documentElement; function setFont() { var html = document.documentElement; var k = 640; html.style.fontSize = html.clientWidth / k * 100 + "px"; } setFont(); setTimeout(function () { setFont(); }, 300); doc.addEventListener('DOMContentLoaded', setFont, false); win.addEventListener('resize', setFont, false); win.addEventListener('load', setFont, false); })(window, document); </script> <style> .swiper-container{width:4.14rem;height:4.88rem;margin:0 auto;position:relative;} .swiper-container img{display:block;width:2.51rem;height:4.41rem;margin:0 auto;} .swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {bottom:0;left:0;width:100%;} .swiper-pagination-bullet-active {background-color:#ffd200;} </style> </head> <body> <div class="swiper-container"> <div class="swiper-wrapper"> <div class="swiper-slide"> <img src="ossweb-img/s-img1.png"> </div> <div class="swiper-slide"> <img src="ossweb-img/s-img2.png"> </div> <div class="swiper-slide"> <img src="ossweb-img/s-img3.png"> </div> <div class="swiper-slide"> <img src="ossweb-img/s-img4.png"> </div> <div class="swiper-slide"> <img src="ossweb-img/s-img5.png"> </div> </div> <div class="swiper-pagination"></div> </div> <!-- 輪播圖 --> <script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/3.4.2/js/swiper.js"></script> <script> // 輪播圖 // 初始化swiper var mySwiper2 = new Swiper('.swiper-container', { autoplay:2000,//自動(dòng)滑動(dòng) speed:500,//自動(dòng)滑動(dòng)開始到結(jié)束的時(shí)間(單位ms) loop:true,//開啟循環(huán) loopedSlides:5,//在loop模式下使用slidesPerview:'auto',還需使用該參數(shù)設(shè)置所要用到的loop個(gè)數(shù)。 slidesPerView:'auto',//設(shè)置slider容器能夠同時(shí)顯示的slides數(shù)量(carousel模式)。另外,支持'auto'值,會(huì)根據(jù)容器container的寬度調(diào)整slides數(shù)目。 effect:'coverflow',//可以實(shí)現(xiàn)3D效果的輪播, pagination:'.swiper-pagination',//分頁(yè)器 centeredSlides:true,//設(shè)定為true時(shí),active slide會(huì)居中,而不是默認(rèn)狀態(tài)下的居左。 coverflow:{ rotate:0,//slide做3d旋轉(zhuǎn)時(shí)Y軸的旋轉(zhuǎn)角度。默認(rèn)50。 stretch:100,//每個(gè)slide之間的拉伸值,越大slide靠得越緊。 默認(rèn)0。 depth:150,//slide的位置深度。值越大z軸距離越遠(yuǎn),看起來(lái)越小。 默認(rèn)100。 modifier:1,//depth和rotate和stretch的倍率,相當(dāng)于depth*modifier、rotate*modifier、stretch*modifier,值越大這三個(gè)參數(shù)的效果越明顯。默認(rèn)1。 slideShadows:false,//開啟slide陰影。默認(rèn) true。 }, }); // rotate :number, //側(cè)轉(zhuǎn)角度(正值凹陷)、(負(fù)值凸出) // stretch : number, //每個(gè)slide之間拉伸值(正值緊貼)、(負(fù)值遠(yuǎn)離) // depth : number, // 正值越大slide為遠(yuǎn)景圖(可負(fù)值) // modifier : number, //depth和rotate和stretch的倍率,值越大這三個(gè)參數(shù)的效果越明顯 // shadows : true //是否使用陰影 </script> </body> </html>
這樣一個(gè)異形輪播圖就好啦!
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
VUE+jszip如何實(shí)現(xiàn)下載多個(gè)文件導(dǎo)出為一個(gè)zip格式
這篇文章主要介紹了VUE+jszip如何實(shí)現(xiàn)下載多個(gè)文件導(dǎo)出為一個(gè)zip格式方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03vue component 中引入less文件報(bào)錯(cuò) Module build failed
這篇文章主要介紹了vue component 中引入less文件報(bào)錯(cuò) Module build failed的解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04使用vue-router完成簡(jiǎn)單導(dǎo)航功能【推薦】
vue-router是Vue.js官方提供的一套專用的路由工具庫(kù)。這篇文章主要介紹了使用vue-router完成簡(jiǎn)單導(dǎo)航功能,需要的朋友可以參考下2018-06-06Vue中使用md5進(jìn)行數(shù)據(jù)加密的實(shí)現(xiàn)方法
在現(xiàn)代Web開發(fā)中,數(shù)據(jù)安全是一個(gè)不可忽視的重要環(huán)節(jié),Vue.js作為一個(gè)流行的前端框架,不僅提供了強(qiáng)大的數(shù)據(jù)綁定和組件化功能,還支持與各種后端服務(wù)的集成,本文將探討如何在Vue應(yīng)用中使用MD5算法來(lái)加密數(shù)據(jù),從而提升應(yīng)用的安全性,需要的朋友可以參考下2024-10-10Vue3.x的版本中build后dist文件中出現(xiàn)legacy的js文件問題
這篇文章主要介紹了Vue3.x的版本中build后dist文件中出現(xiàn)legacy的js文件問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07vue實(shí)現(xiàn)后臺(tái)管理權(quán)限系統(tǒng)及頂欄三級(jí)菜單顯示功能
這篇文章主要介紹了vue實(shí)現(xiàn)后臺(tái)管理權(quán)限系統(tǒng)及頂欄三級(jí)菜單顯示功能,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06vue項(xiàng)目?jī)?yōu)雅實(shí)現(xiàn)自動(dòng)引入組件的方法詳解
在我們寫vue項(xiàng)目的時(shí)候,都會(huì)引入一些組件庫(kù),有時(shí)候有可能還不止一個(gè)組件庫(kù),那么如何優(yōu)雅的實(shí)現(xiàn)自動(dòng)引入組件呢,下面小編就來(lái)和大家詳細(xì)講講吧2023-09-09