vue+rem自定義輪播圖效果
使用vue+rem自定義輪播圖的實(shí)現(xiàn),供大家參考,具體內(nèi)容如下
單位使用rem進(jìn)行頁面布局,在動(dòng)態(tài)計(jì)算輪播圖整體寬度時(shí),需要把px轉(zhuǎn)換成rem,挺麻煩的。
效果如下:如果當(dāng)前圖片不是第一張和最后一張,剛好可以看到當(dāng)前圖片上一張和下一張的一部分。

具體代碼如下
<template>
<div class="constructionUp">
<div class="pub-hd">
<h2>施工升級(jí)包</h2>
<h3>額外服務(wù)項(xiàng)目</h3>
</div>
<div id="activityDiv">
<ul num="0" id="activityUl">
<li class="activityLi" v-for="(v,i) in listData" :key="i" @touchstart.capture="touchStart" @touchend.capture="touchEnd">
<img src="static/imgs/package/bitmap.jpg">
<div class="liText">
<p class="liTtitle">{{v.lititle}}</p>
<p class="liDes">1、開工后,客戶、設(shè)計(jì)師、項(xiàng)目管家三方進(jìn)行現(xiàn)場(chǎng)交底,若有個(gè)性化項(xiàng)目變更,執(zhí)行正常的客戶變更手續(xù)(參照:客戶變更告知書);</p>
<p class="liDes">2、交底后,若客戶原因要求個(gè)性化項(xiàng)目變更,除了承擔(dān)個(gè)性化項(xiàng)目的費(fèi)用外,還要增/次的調(diào)撥費(fèi)用。</p>
<p class="liPrice">
<span class="title1">主題包價(jià)格:¥</span>
<span class="title2">4500</span>
<span class="title3">元</span>
</p>
</div>
</li>
</ul>
<div class="pointerDiv">
<span :class="[currantIndex ===0 ? 'active' : '', 'pointer']"></span>
<span :class="[currantIndex ===1 ? 'active' : '', 'pointer']"></span>
<span :class="[currantIndex ===2 ? 'active' : '', 'pointer']"></span>
</div>
</div>
</div>
</template>
<script>
export default {
data () {
return {
listData: [{lititle: '舊房改造'}, {lititle: '舊房改造2'}, {lititle: '舊房改造3'}],
liWidth: 0,
liNum: 0,
startX: 0,
endX: 0,
currantIndex: 0,
test: false
}
},
mounted () {
this.initUlWidth()
},
methods: {
initUlWidth () { // 初始化 ul的寬度
let pit = document.documentElement.clientWidth / 750 // 當(dāng)前手機(jī)屏幕和750屏幕的比例
let oldWidth = document.getElementsByClassName('activityLi')[0].offsetWidth // 單個(gè)li的寬度
let marginR = getComputedStyle(document.getElementsByClassName('activityLi')[0], null)['marginRight'] // 獲取單個(gè)的marginRight,帶px
let marginNum = parseInt(marginR.replace('px', ''))
this.liWidth = oldWidth + marginNum // 單個(gè)寬度+maringRight
let liCount = parseInt(document.getElementsByClassName('activityLi').length)// li的個(gè)數(shù)
this.liNum = liCount
let ULpx = oldWidth * liCount + (liCount - 1) * marginNum // 最后一個(gè)margin不算
document.getElementById('activityUl').style.width = ULpx / pit + 'px'// 除以比率,讓當(dāng)前div寬度與2倍設(shè)計(jì)比例一樣,設(shè)置ul的長度最后那個(gè)margin不算
},
touchStart (e) {
// 記錄初始位置
e.preventDefault() // 阻止默認(rèn)事件,滾動(dòng)等
this.startX = e.touches[0].clientX // 記錄滑動(dòng)開始的位置
},
touchEnd (e) {
e.preventDefault() // 阻止默認(rèn)事件
// 記錄結(jié)束位置
this.endX = e.changedTouches[0].clientX
// 左滑
if (this.startX - this.endX > 30) {
console.log('左滑')
if (this.currantIndex >= this.liNum - 1) {
// 不做操作
} else {
this.currantIndex++
document.getElementById('activityUl').style.left = -this.currantIndex * this.liWidth + 'px'
}
}
// 右滑
if (this.startX - this.endX < -30) {
if (this.currantIndex === 0) {
// 不做操作
} else {
this.currantIndex--
document.getElementById('activityUl').style.left = -this.currantIndex * this.liWidth + 'px'
}
}
this.startX = 0
this.endX = 0
}
}
}
</script>
<style lang="less" scoped>
@import "~less/base.less";
.constructionUp{
width: 100%;
.pub-hd{
padding: 0.8rem 0 0.6rem 0;
text-align: center;
background-color: #ffffff;
h2{
font-size: 0.32rem;
color: #606771;
}
h3{
margin-top: 0.26rem;
font-size: 0.24rem;
color: #b9bec4;
}
}
#activityDiv{
padding-left: 0.4rem;
background-color: #ffffff;
overflow: hidden;
#activityUl{
position: relative;
left: 0;
height: 8.06rem;
transition:all .35s ease-in-out;
background-color: #ffffff;
.activityLi{
float: left;
width: 6.7rem;
height: 8.06rem;
&:not(:last-child){
margin-right: 0.3rem;
}
box-shadow: 0 5px 25px 0 rgba(0,0,0,.4);
img{
width: 100%;
height: 3.6rem;
}
.liText{
padding: 0 0.4rem;
text-align: left;
.liTtitle{
padding: 0.48rem 0 0.36rem 0;
font-size: 0.34rem;
color: #000000;
}
.liDes{
font-size: 0.2rem;
color:#b5b5b5;
}
}
.liPrice{
height: 0.28rem;
line-height: 0.28rem;
color: @c-main; //顏色換一下就好
vertical-align: bottom;
margin-top: 0.8rem;
.title1{
display: inline-block;
font-size: 0.22rem;
}
.title2{
display: inline-block;
font-size: 0.35rem;
}
.title3{
display: inline-block;
font-size: 0.22rem;
}
}
}
}
.pointerDiv{
width: 100%;
height: 1.54rem;
background-color: #ffffff;
display: flex;
align-items: center;
justify-content: center;
.pointer{
display: inline-block;
width: 0.16rem;
height: 0.16rem;
background-color: #cccccc;
border-radius: 100%;
&:nth-child(2){
margin:0 0.4rem;
}
&.active{
background-color: @c-main;
}
}
}
}
}
</style>
關(guān)于vue.js組件的教程,請(qǐng)大家點(diǎn)擊專題vue.js組件學(xué)習(xí)教程進(jìn)行學(xué)習(xí)。
更多vue學(xué)習(xí)教程請(qǐng)閱讀專題《vue實(shí)戰(zhàn)教程》
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue使用smooth-signature實(shí)現(xiàn)移動(dòng)端橫豎屏電子簽字
這篇文章主要為大家介紹了vue使用smooth-signature實(shí)現(xiàn)移動(dòng)端橫豎屏電子簽字示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
使用idea創(chuàng)建第一個(gè)Vue項(xiàng)目
最近在學(xué)習(xí)vue,本文主要介紹了使用idea創(chuàng)建第一個(gè)Vue項(xiàng)目,文中根據(jù)圖文介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
vue3組件化開發(fā)常用API知識(shí)點(diǎn)總結(jié)
Vue是目前Web前端最流行的開發(fā)框架技術(shù),?下面這篇文章主要給大家介紹了關(guān)于vue3組件化開發(fā)常用API的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
vue基于echarts實(shí)現(xiàn)立體柱形圖
這篇文章主要為大家詳細(xì)介紹了vue基于echarts實(shí)現(xiàn)立體柱形圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vue init webpack 建vue項(xiàng)目報(bào)錯(cuò)的解決方法
今天小編就為大家分享一篇vue init webpack 建vue項(xiàng)目報(bào)錯(cuò)的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09

