Browse Source

优化me页面

pull/19/head
zyronon 4 years ago
parent
commit
2407977d39
  1. 3
      src/components/Posters.vue
  2. 2
      src/components/slide/SlideRowList.vue
  3. 420
      src/pages/me/Me2.vue

3
src/components/Posters.vue

@ -29,16 +29,17 @@ export default { @@ -29,16 +29,17 @@ export default {
.posters {
display: grid;
grid-template-columns: 33.33vw 33.33vw 33.33vw;
grid-template-rows:calc(33.33vw * 1.2);
}
.poster-item {
height: calc(33.33vw * 1.2);
border: 1px solid black;
overflow: hidden;
position: relative;
.poster {
width: 100%;
height: 100%;
display: block;
}

2
src/components/slide/SlideRowList.vue

@ -21,7 +21,7 @@ @@ -21,7 +21,7 @@
<div class="loading" :style="loadingStyle">AA</div>
</div>
<div id="base-slide-list" ref="slideList"
:style="{'flex-direction':'row',marginTop:indicatorFixed?'42px':'0'}"
:style="{'flex-direction':'row',marginTop:indicatorFixed?'5rem':'0'}"
@touchstart="touchStart($event)"
@touchmove="touchMove($event)"
@touchend="touchEnd($event)">

420
src/pages/me/Me2.vue

@ -8,47 +8,100 @@ @@ -8,47 +8,100 @@
@touchmove="touchMove($event)"
@touchend="touchEnd($event)">
<div ref="desc" class="desc">
<div style="height: 380px;"></div>
</div>
<div ref="content" class="test " :class="isFixed?'fixed':''" style="margin-bottom: 60px;">
<Indicator
name="videoList"
:fixed="indicatorFixed"
tabStyleWidth="25%"
:tabTexts="['作品','私密','喜欢','收藏']"
v-model:active-index="contentIndex">
</Indicator>
<SlideRowList
name="videoList"
:indicator-fixed="indicatorFixed"
v-model:active-index="contentIndex">
<SlideItem style="overflow: auto;height: 100vh;">
<div ref="tab-content1">
<Posters :list="25"></Posters>
<div class="no-more">暂时没有更多了</div>
<header ref="header">
<div class="left" style="opacity: 0;">
<img src="../../assets/img/icon/next.svg" alt="">
<span>切换账号</span>
</div>
<div class="right">
<img 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 class="detail">
<div class="head">
<img src="../../assets/img/icon/head-image.jpeg" class="head-image">
<div class="other-buttons" v-if="false">
<div class="attention">
关注
</div>
<div class="more-attention">
-
</div>
</div>
</SlideItem>
<SlideItem>
<div ref="tab-content2">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
<div class="my-buttons ">
<div class="collect" @click="$nav('/edit-userinfo')">
<span class="mr1r">编辑资料</span>
<span class="f10p" style="color: darkgray">85%</span>
</div>
<div class="add-friend" @click="$nav('/find-acquaintance')">
<img src="../../assets/img/icon/add-white.png" alt="">
<span class="mr5p">熟人</span>
</div>
</div>
</div>
<div class="description">
<p class="name f22 mt1r mb1r">ttentau</p>
<div class="number mb1r">
<span class="mr1r">私密账号</span>
<span>抖音号605128307</span>
<img src="../../assets/img/icon/me/qrcode-gray.png" alt="" @click.stop="$nav('/my-card')">
</div>
</SlideItem>
<SlideItem>
<div ref="tab-content3">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
<div class="signature f12 mb1r">
<span>填写个性签名更容易获得别人关注哦</span>
</div>
</SlideItem>
<SlideItem>
<div ref="tab-content3">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
<div class="heat">
<div class="text"><span class="num">8</span>获赞</div>
<div class="text"><span class="num">8</span>关注</div>
<div class="text"><span class="num">8</span>粉丝</div>
</div>
</SlideItem>
</SlideRowList>
</div>
</div>
</div>
<Indicator
name="videoList"
tabStyleWidth="25%"
:tabTexts="['作品','私密','喜欢','收藏']"
v-model:active-index="contentIndex">
</Indicator>
<SlideRowList
name="videoList"
style="height: calc(100vh - 9.5rem);"
v-model:active-index="contentIndex">
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="25"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
<SlideItem class="SlideItem"
@touchmove="move"
:style="isScroll?'overflow: auto;':''">
<Posters :list="5"></Posters>
<div class="no-more">暂时没有更多了</div>
</SlideItem>
</SlideRowList>
</div>
<Indicator
v-if="indicatorFixed"
name="videoList"
:fixed="true"
tabStyleWidth="25%"
:tabTexts="['作品','私密','喜欢','收藏']"
v-model:active-index="contentIndex">
</Indicator>
<Footer v-bind:init-tab="5"/>
</SlideItem>
<SlideItem style="min-width: 70vw; overflow:auto;">
@ -164,7 +217,6 @@ export default { @@ -164,7 +217,6 @@ export default {
components: {Posters, Footer, Indicator},
data() {
return {
isFixed: false,
serviceEl: {},
serviceHeight: 0,
contentIndex: 0,
@ -173,13 +225,17 @@ export default { @@ -173,13 +225,17 @@ export default {
tabContents: [],
indicatorHeight: 42,
indicatorFixed: false,
isScroll: false,
refs: {
header: null,
headerHeight: 0,
descHeight: 0,
},
isMoreFunction: false,
startLocationY: 0,
fixedLocationY: 0,
moveYDistance: 0,
startTime: 0,
}
},
computed: {
@ -188,26 +244,153 @@ export default { @@ -188,26 +244,153 @@ export default {
},
},
mounted() {
setTimeout(() => {
this.refs.header = this.$refs.header
this.refs.headerHeight = this.$refs.header.offsetHeight
this.refs.descHeight = this.$refs.desc.offsetHeight
this.changeIndex(0, null)
})
},
methods: {
changeIndex() {
},
touchStart(e) {
this.startLocationY = e.touches[0].pageY
this.$refs.scroll.style.transition = 'none'
this.fixedLocationY = this.startLocationY = e.touches[0].pageY
this.startTime = Date.now()
},
move(e) {
(!this.isScroll) && e.preventDefault();
},
touchMove(e) {
let distance = this.moveYDistance + e.touches[0].pageY - this.startLocationY
console.log(distance)
if (this.indicatorFixed && Math.abs(distance) > 380) {
// console.log('pageY', e.touches[0].pageY)
// console.log('moveYDistance', this.moveYDistance)
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
// if (this.refs.header.getBoundingClientRect().top !== 0) return
this.refs.header.style.transition = 'all 0s'
this.refs.header.style.height = this.refs.headerHeight + (distance / 2) + 'px'
} else {
this.startLocationY = e.touches[0].pageY
this.moveYDistance = 400
}
return
}
// console.log('s', e.touches[0].pageY - this.startLocationY)
// console.log('indicatorFixed', this.indicatorFixed)
if (this.indicatorFixed) {
let SlideItems = document.querySelectorAll('.SlideItem')
let SlideItem = SlideItems[this.contentIndex]
// console.log(tt.scrollTop)
if (!this.isScroll) {
SlideItem.style.overflow = 'auto'
SlideItem.scrollTop = Math.abs(distance) - this.refs.descHeight
}
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
}
} else {
this.indicatorFixed = Math.abs(distance) > this.refs.descHeight
if (this.indicatorFixed) {
this.fixedLocationY = e.touches[0].pageY
}
this.$refs.scroll.style.transform = `translate3d(0,${distance}px,0)`
}
this.indicatorFixed = Math.abs(distance) > 380
this.$refs.scroll.style.transform = `translate3d(0,${distance}px,0)`
},
touchEnd(e) {
this.moveYDistance = this.moveYDistance + e.changedTouches[0].pageY - this.startLocationY
console.log('end', this.moveYDistance)
this.indicatorFixed = Math.abs(this.moveYDistance) > 380
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
}
//
//
if (!this.indicatorFixed) {
//
let distance = e.changedTouches[0].pageY - this.startLocationY
// console.log('end-distance', distance)
let endTime = Date.now()
let gapTime = endTime - this.startTime
//
if (Math.abs(distance) < 20) gapTime = 1000
//header1/3
if (Math.abs(distance) > (this.refs.descHeight / 2)) gapTime = 50
// console.log('', gapTime)
if (gapTime < 150) {
//
if (distance > 0) {
//
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)
//transformY
transformY = parseInt(transformY)
// console.log('transformY', transformY)
let timer
cancelAnimationFrame(timer);
let fn = () => {
//
if (transformY < 0) {
transformY = transformY + 40
this.$refs.scroll.style.transform = `translate3d(0,${transformY > 0 ? 0 : transformY}px,0)`
timer = requestAnimationFrame(fn);
} else {
//transformY === 0,
if (transformY !== 0) {
if (this.$getCss(this.refs.header, 'height') < 400) {
this.refs.header.style.transition = 'none'
this.refs.header.style.height = this.$getCss(this.refs.header, 'height') + 10 + 'px'
timer = requestAnimationFrame(fn);
} else {
this.refs.header.style.transition = 'all .6s'
this.refs.header.style.height = this.refs.headerHeight + 'px'
this.moveYDistance = 0
cancelAnimationFrame(timer);
}
} else {
//
this.moveYDistance = 0
cancelAnimationFrame(timer);
}
}
}
timer = requestAnimationFrame(fn);
} 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
}
} 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.isScroll = Math.abs(this.moveYDistance) > this.refs.descHeight
}
}
}
@ -239,6 +422,151 @@ export default { @@ -239,6 +422,151 @@ 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;
display: flex;
justify-content: space-between;
/*background: url("../../assets/img/icon/top-bg.jpg");*/
padding: 2rem;
box-sizing: border-box;
.left {
font-size: 1.2rem;
height: 2.6rem;
display: flex;
padding-right: 1.3rem;
padding-left: .5rem;
align-items: center;
border-radius: 2rem;
background: rgba(82, 80, 80, 0.5);
img {
padding: .6rem;
width: 1.8rem;
}
}
.right {
img {
margin-left: 2rem;
border-radius: 50%;
background: rgba(82, 80, 80, 0.5);
padding: .6rem;
width: 1.8rem;
}
}
&.bound-anim {
animation: anim .6s;
}
@keyframes anim {
0% {
height: 15rem;
}
25% {
height: 30rem;
}
100% {
height: 15rem;
}
}
}
.detail {
background: $main-bg;
padding: 0 20px;
.head {
width: 100%;
display: flex;
justify-content: space-between;
align-items: center;
box-sizing: border-box;
transform: translateY(-20px);
.head-image {
background: black;
padding: 2px;
border-radius: 50%;
width: 80px;
height: 80px;
}
.my-buttons {
div {
font-size: 1.2rem;
display: flex;
align-items: center;
justify-content: center;
float: left;
border-radius: 2px;
background: $second-btn-color;
margin-left: 5px;
padding: 0 10px;
height: 30px;
color: white;
&:nth-child(1) {
padding: 0 25px;
}
img {
padding: 0 .6rem;
height: 1.2rem;
}
}
}
}
.description {
font-size: 1.2rem;
color: white;
transform: translateY(-20px);
.number {
color: $second-text-color;
padding-bottom: 2rem;
border-bottom: 1px solid $line-color;
display: flex;
align-items: center;
img {
width: 18px;
margin-left: 5px;
}
}
.heat {
color: darkgray;
display: flex;
align-items: center;
.num {
color: white;
font-size: 1.8rem;
font-weight: bold;
margin-right: 3px;
}
.text {
font-size: 1.4rem;
margin-right: 10px;
}
}
}
}
}
.ul {
font-size: 1.4rem;
width: 100%;

Loading…
Cancel
Save