Browse Source

优化me页面2

pull/19/head
zyronon 4 years ago
parent
commit
12d2553225
  1. 15
      src/components/Posters.vue
  2. 2
      src/pages/me/Me.vue
  3. 186
      src/pages/me/Me2.vue
  4. 13
      src/utils/global-methods.js

15
src/components/Posters.vue

@ -1,10 +1,10 @@ @@ -1,10 +1,10 @@
<template>
<div class="posters">
<div class="poster-item" v-for="i in list">
<img class="poster" src="../assets/img/poster/2.jpg" alt="">
<img class="poster" :src="i.src" alt="">
<div class="num">
<img class="love" src="../assets/img/icon/love.svg" alt="">
<span>123.2w</span>
<span>{{ likeNum(i.like) }}</span>
</div>
</div>
</div>
@ -18,7 +18,16 @@ export default { @@ -18,7 +18,16 @@ export default {
list: {
type: [Array, Number],
default: () => {
return 5
return []
}
}
},
methods: {
likeNum(num) {
if (num < 1000) {
return num
} else {
return num / 10000 + 'w'
}
}
}

2
src/pages/me/Me.vue

@ -205,8 +205,6 @@ export default { @@ -205,8 +205,6 @@ export default {
components: {Posters, Footer, Indicator},
data() {
return {
serviceEl: {},
serviceHeight: 0,
contentIndex: 0,
baseActiveIndex: 0,
desc: null,

186
src/pages/me/Me2.vue

@ -2,22 +2,28 @@ @@ -2,22 +2,28 @@
<div class="Me">
<SlideRowList style="width: 100vw;" v-model:active-index="baseActiveIndex">
<SlideItem>
<div class="scroll"
ref="scroll"
@touchstart="touchStart($event)"
@touchmove="touchMove($event)"
@touchend="touchEnd($event)">
<div ref="desc" class="desc">
<header ref="header">
<div ref="float" class="float" :class="floatFixed?'fixed':''">
<div class="left" style="opacity: 0;">
<img src="../../assets/img/icon/next.svg" alt="">
<span>切换账号</span>
</div>
<transition name="fade">
<div class="center" v-if="floatShowName">
<p class="name f22 mt1r mb1r">ttentau</p>
</div>
</transition>
<div class="right">
<img src="../../assets/img/icon/me/finger-right.png" alt="">
<img :style="floatFixed?'opacity: 0;':''" src="../../assets/img/icon/me/finger-right.png" alt="">
<img src="../../assets/img/icon/me/menu.png" alt="" @click.stop="baseActiveIndex = 1">
</div>
</header>
</div>
<div class="scroll"
ref="scroll"
@touchstart="touchStart($event)"
@touchmove="touchMove($event)"
@touchend="touchEnd($event)">
<div ref="desc" class="desc">
<header ref="header"></header>
<div class="detail">
<div class="head">
<img src="../../assets/img/icon/head-image.jpeg" class="head-image">
@ -66,35 +72,36 @@ @@ -66,35 +72,36 @@
</Indicator>
<SlideRowList
name="videoList"
style="height: calc(100vh - 9.5rem);"
style="height: calc(100vh - 14rem);"
v-model:active-index="contentIndex">
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="25"></Posters>
<Posters :list="res.my"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<Posters :list="res.private"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<Posters :list="res.like"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<Posters :list="res.collect"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
</SlideRowList>
</div>
<Indicator
style="margin-top: 4.6rem;"
v-if="indicatorFixed"
name="videoList"
:fixed="true"
@ -105,7 +112,7 @@ @@ -105,7 +112,7 @@
<Footer v-bind:init-tab="5"/>
</SlideItem>
<SlideItem style="min-width: 70vw; overflow:auto;">
<transition name="fade">
<transition name="fade1">
<div class="ul" v-if="!isMoreFunction">
<div class="li" @click="$nav('/my-card')">
<img src="../../assets/img/icon/newicon/left_menu/shopping.png" alt="">
@ -217,25 +224,32 @@ export default { @@ -217,25 +224,32 @@ export default {
components: {Posters, Footer, Indicator},
data() {
return {
serviceEl: {},
serviceHeight: 0,
contentIndex: 0,
baseActiveIndex: 0,
desc: null,
tabContents: [],
indicatorHeight: 42,
indicatorFixed: false,
floatFixed: false,
floatShowName: false,
isScroll: false,
isMoreFunction: false,
refs: {
header: null,
headerHeight: 0,
descHeight: 0,
},
isMoreFunction: false,
startLocationY: 0,
fixedLocationY: 0,
moveYDistance: 0,
startTime: 0,
floatHeight: 46,
res: {
my: [],
private: [],
like: [],
collect: []
}
}
},
computed: {
@ -250,8 +264,37 @@ export default { @@ -250,8 +264,37 @@ export default {
this.refs.descHeight = this.$refs.desc.offsetHeight
this.changeIndex(0, null)
})
// this.getData()
// res.my
},
methods: {
getData() {
// for (let i = 0; i < this.$randomNum(15, 30); i++) {
// this.res.my.push({
// src: require(`../../assets/img/poster/${this.$randomNum(11)}.jpg`),
// like: this.$randomNum(99) * 10000
// })
// }
// for (let i = 0; i < this.$randomNum(0, 5); i++) {
// this.res.private.push({
// src: require(`../../assets/img/poster/${this.$randomNum(11)}.jpg`),
// like: this.$randomNum(99) * 10000
// })
// }
// for (let i = 0; i < this.$randomNum(200); i++) {
// this.res.like.push({
// src: require(`../../assets/img/poster/${this.$randomNum(11)}.jpg`),
// like: this.$randomNum(99) * 10000
// })
// }
// for (let i = 0; i < this.$randomNum(10); i++) {
// this.res.collect.push({
// src: require(`../../assets/img/poster/${this.$randomNum(11)}.jpg`),
// like: this.$randomNum(99) * 10000
// })
// }
console.log(this.res)
},
changeIndex() {
},
@ -269,6 +312,7 @@ export default { @@ -269,6 +312,7 @@ export default {
let moveYDistance = e.touches[0].pageY - this.startLocationY
let distance = this.moveYDistance + moveYDistance * 1.2
// console.log('distance', distance)
//
if (distance > 0) {
if (distance < 400) {
// if (this.baseActiveIndex !== 0) return
@ -290,37 +334,44 @@ export default { @@ -290,37 +334,44 @@ export default {
// console.log(tt.scrollTop)
if (!this.isScroll) {
SlideItem.style.overflow = 'auto'
SlideItem.scrollTop = Math.abs(distance) - this.refs.descHeight
SlideItem.scrollTop = Math.abs(distance) - this.refs.descHeight + this.floatHeight
}
if (SlideItem.scrollTop === 0 && (e.touches[0].pageY - this.fixedLocationY) > 0) {
this.isScroll = this.indicatorFixed = false
SlideItem.style.overflow = 'hidden'
this.startLocationY = e.touches[0].pageY
this.moveYDistance = -this.refs.descHeight
this.moveYDistance = -this.refs.descHeight + this.floatHeight
}
} else {
this.indicatorFixed = Math.abs(distance) > this.refs.descHeight
this.indicatorFixed = Math.abs(distance) > this.refs.descHeight - this.floatHeight
this.floatFixed = Math.abs(distance) > 100
this.floatShowName = Math.abs(distance) > 150
if (this.indicatorFixed) {
this.fixedLocationY = e.touches[0].pageY
}
this.$refs.scroll.style.transform = `translate3d(0,${distance}px,0)`
}
},
touchEnd(e) {
console.log('this.startLocationY', this.startLocationY)
// console.log('this.startLocationY', this.startLocationY)
let moveYDistance = e.changedTouches[0].pageY - this.startLocationY
this.moveYDistance = this.moveYDistance + moveYDistance * 1.2//1.2
// console.log('end-moveYDistance', this.moveYDistance)
//header
if (this.moveYDistance > 0) {
// if (this.baseActiveIndex !== 0) return
this.refs.header.style.transition = 'all .3s'
this.refs.header.style.height = this.refs.headerHeight + 'px'
this.moveYDistance = 0
this.floatShowName = this.floatFixed = this.isScroll = false
return
}
// console.log('header-height',this.refs.descHeight - this.floatHeight)
// this.isScroll = Math.abs(this.moveYDistance) > this.refs.descHeight - this.floatHeight
//
//
if (!this.indicatorFixed) {
@ -339,13 +390,12 @@ export default { @@ -339,13 +390,12 @@ export default {
//
if (distance > 0) {
//
gapTime = endTime - this.startTime
if (gapTime < 100 && Math.abs(distance) > 100) {
//cancelAnimationFrametransition = 'all .3s'
this.$refs.scroll.style.transition = 'none'
let transform = this.$refs.scroll.style.transform
let transformY = transform.substring(transform.indexOf('0px') + 5, transform.lastIndexOf('0px') - 4)
let transformY = this.getTransform(this.$refs.scroll)
//transformY
transformY = parseInt(transformY)
// console.log('transformY', transformY)
let timer
cancelAnimationFrame(timer);
@ -382,15 +432,25 @@ export default { @@ -382,15 +432,25 @@ export default {
this.$refs.scroll.style.transform = `translate3d(0,${distance > 0 ? 0 : -this.refs.descHeight}px,0)`
this.moveYDistance = distance > 0 ? 0 : -this.refs.descHeight
}
this.floatShowName = this.floatFixed = this.isScroll = false
} else {
//
this.$refs.scroll.style.transition = 'all .3s'
this.$refs.scroll.style.transform = `translate3d(0,${distance > 0 ? 0 : -this.refs.descHeight}px,0)`
this.moveYDistance = distance > 0 ? 0 : -this.refs.descHeight
this.$refs.scroll.style.transform = `translate3d(0,${distance > 0 ? 0 : -this.refs.descHeight + this.floatHeight}px,0)`
this.moveYDistance = distance > 0 ? 0 : -this.refs.descHeight + this.floatHeight
this.floatShowName = this.floatFixed = this.isScroll = true
}
}
}
this.isScroll = Math.abs(this.moveYDistance) > this.refs.descHeight
// console.log('end-isScroll', this.isScroll)
},
getTransform(el) {
let transform = el.style.transform
let transformY = transform.substring(transform.indexOf('0px') + 5, transform.lastIndexOf('0px') - 4)
//transformY
transformY = parseInt(transformY)
return transformY
}
}
}
@ -399,13 +459,13 @@ export default { @@ -399,13 +459,13 @@ export default {
<style scoped lang='scss'>
@import "../../assets/scss/index";
.fade-enter-active,
.fade-leave-active {
.fade1-enter-active,
.fade1-leave-active {
transition: all 0.3s ease;
}
.fade-enter-from,
.fade-leave-to {
.fade1-enter-from,
.fade1-leave-to {
transform: translateY(10px);
opacity: 0;
}
@ -422,20 +482,31 @@ export default { @@ -422,20 +482,31 @@ export default {
text-align: center;
}
.desc {
header {
color: white;
height: 12rem;
background-image: url('../../assets/img/header-bg.png');
//background-image: url('');
background-size: cover;
background-position: center;
background-repeat: no-repeat;
.float {
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 2;
display: flex;
justify-content: space-between;
/*background: url("../../assets/img/icon/top-bg.jpg");*/
padding: 2rem;
box-sizing: border-box;
align-items: center;
height: 4.6rem;
padding: 0 1.5rem;
background: transparent;
transition: all .2s;
.center {
color: white;
}
&.fixed {
background: $main-bg;
img {
background: $main-bg !important;
}
}
.left {
font-size: 1.2rem;
@ -462,22 +533,19 @@ export default { @@ -462,22 +533,19 @@ export default {
width: 1.8rem;
}
}
&.bound-anim {
animation: anim .6s;
}
@keyframes anim {
0% {
height: 15rem;
}
25% {
height: 30rem;
}
100% {
height: 15rem;
}
}
.desc {
header {
color: white;
height: 12rem;
background-image: url('../../assets/img/header-bg.png');
//background-image: url('');
background-size: cover;
background-position: center;
background-repeat: no-repeat;
box-sizing: border-box;
}
.detail {

13
src/utils/global-methods.js

@ -151,6 +151,19 @@ export default { @@ -151,6 +151,19 @@ export default {
$console(v) {
return console.log(JSON.stringify(v, null, 4))
},
$randomNum(minNum,maxNum){
switch(arguments.length){
case 1:
return parseInt(Math.random()*minNum+1,10);
break;
case 2:
return parseInt(Math.random()*(maxNum-minNum+1)+minNum,10);
break;
default:
return 0;
break;
}
},
$duration(v) {
let m = Math.floor(v / 60)
// let s = v % 60

Loading…
Cancel
Save