douyin/src/pages/home/Me.vue
2019-08-03 23:54:03 +08:00

955 lines
42 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<div class="Me" >
<div class="wrapper">
<div class="left">
<header>
<img src="../../assets/img/icon/next.svg" alt="" @click="$emit('back')">
<img src="../../assets/img/icon/more.svg" alt="" @click="nav('myCard')">
</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>
<div class="my-buttons ">
<div class="collect">
<img src="../../assets/img/icon/collect-white.svg" alt="">
<span class="mr5p">收藏</span>
</div>
<div class="add-friend">
<img src="../../assets/img/icon/add-friend-white.svg" alt="">
</div>
<div class="qr-code">
<img src="../../assets/img/icon/qr-code-white.svg" alt="">
</div>
</div>
</div>
<div class="description">
<p class="name f22 mt5p mb5p">ttentau</p>
<div class="number mb10p">
<span>抖音号605128307</span>
<div class="jrtt">
<img src="../../assets/img/icon/sina.svg" alt="">
<span>头条主页</span>
<img src="../../assets/img/icon/next.svg" alt="">
</div>
</div>
<div class="signature f12 mb10p">
<span>填写个性签名更容易获得别人关注哦</span>
</div>
<div class="info f10 mb10p">
<div class="age">
<img src="../../assets/img/icon/person.svg" alt="">
<span>22</span>
</div>
<div class="location">
<span>上海</span>
</div>
<div class="school">
四川理工大学
</div>
</div>
<div class="heat">
<span>8获赞</span>
<span>38关注</span>
<span>42粉丝</span>
</div>
</div>
</div>
<div class="indicator-ctn">
<div class="tabs-text-ctn">
<div class="tab-text active">作品1</div>
<div class="tab-text">作品1</div>
<div class="tab-text">作品1</div>
</div>
<div class="indicator"></div>
</div>
<div class="tabs-ctn">
<div class="tabs">
<div class="tab tab1">
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
</div>
<div class="tab tab2">
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
</div>
<div class="tab tab3">
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
<p>12</p>
</div>
</div>
</div>
<my-footer v-bind:init-tab="5"></my-footer>
</div>
<div class="right">
<ul>
<li @click="nav('myCard')">
<img src="../../assets/img/icon/card-gray.png" alt="">
<span>个人名片</span>
</li>
<li>
<img src="../../assets/img/icon/collect-gray.png" alt="">
<span>我的收藏</span>
</li>
<div class="line"></div>
<li>
<img src="../../assets/img/icon/wallet-gray.png" alt="">
<span>钱包</span>
</li>
<li>
<img src="../../assets/img/icon/order-gray.png" alt="">
<span>订单</span>
</li>
<li class="exception" @click="toggleService()">
<div class="d-flex align-items-center">
<img src="../../assets/img/icon/category-gray.png" alt="">
<span>服务</span>
</div>
<div class="triangle"></div>
</li>
<div class="service">
<li>
<img src="../../assets/img/icon/order-gray.png" alt="" class="op0">
<span>购物助手</span>
</li>
<li>
<img src="../../assets/img/icon/order-gray.png" alt="" class="op0">
<span>生活服务订单</span>
</li>
<li>
<img src="../../assets/img/icon/order-gray.png" alt="" class="op0">
<span>DOU+ 上热门</span>
</li>
<li>
<img src="../../assets/img/icon/order-gray.png" alt="" class="op0">
<span>彩铃服务</span>
</li>
<li>
<img src="../../assets/img/icon/order-gray.png" alt="" class="op0">
<span>免流量看抖音</span>
</li>
</div>
<div class="line"></div>
<li>
<img src="../../assets/img/icon/link-gray.png" alt="">
<span>小程序</span>
</li>
<li>
<img src="../../assets/img/icon/juan-gray.png" alt="">
<span>卡卷</span>
</li>
<div class="line"></div>
<li>
<img src="../../assets/img/icon/umbrella-gray.png" alt="">
<span>未成年保护工具</span>
</li>
<div class="line"></div>
<li>
<img src="../../assets/img/icon/setting-gray.png" alt="">
<span>设置</span>
</li>
</ul>
</div>
</div>
</div>
</template>
<script>
import Footer from '../../components/Footer'
export default {
name: "Me",
components: { 'my-footer': Footer },
data() {
return {
serviceEl: {},
serviceHeight: 0
}
},
created() {
},
mounted() {
!function () {
let wrapper = document.querySelector('.wrapper')
let leftEl = document.querySelector('.left')
let header = document.querySelector('header')
let headerHeight = getCss(header, 'height')
let indicatorCtn = document.querySelector('.indicator-ctn')
let indicatorCtnOffsetTop = indicatorCtn.offsetTop
let startLocationX = 0
let startLocationY = 0
let lastLocationX = 0
let lastLocationY = 0
let moveXDistance = 0
let moveYDistance = 0
let judgeValue = 20
let startTime
let currentSwiperItemIndex
let isDrawRight
let isCanRightWiping = false
let isCanDownWiping = false
let isNeedCheck = true
let width = document.body.clientWidth
let rightWidth = width * 0.7
wrapper.addEventListener('touchstart', function (e) {
wrapper.style.transition = 'none'
header.style.transition = 'none'
let left = getCss(wrapper, 'left')
if (left !== 0) {
currentSwiperItemIndex = 1
} else {
currentSwiperItemIndex = 0
}
startLocationX = e.touches[0].pageX
startLocationY = e.touches[0].pageY
startTime = Date.now()
})
wrapper.addEventListener('touchmove', function (e) {
lastLocationX = e.touches[0].pageX
lastLocationY = e.touches[0].pageY
moveXDistance = lastLocationX - startLocationX
moveYDistance = lastLocationY - startLocationY
checkDirection()
if (isCanRightWiping) {
if (currentSwiperItemIndex === 0) {
if (moveXDistance > 0) {
moveXDistance = 0
}
if (Math.abs(moveXDistance) > rightWidth) {
moveXDistance = -rightWidth
}
isDrawRight = moveXDistance < 0
if (isDrawRight) {
wrapper.style.left = -(currentSwiperItemIndex + 0) * width + moveXDistance + judgeValue + 'px'
} else {
wrapper.style.left = -(currentSwiperItemIndex + 0) * width + moveXDistance + 'px'
}
}
if (currentSwiperItemIndex === 1) {
if (moveXDistance < 0) {
moveXDistance = 0
}
isDrawRight = moveXDistance < 0
if (isDrawRight) {
wrapper.style.left = -(currentSwiperItemIndex + 0) * rightWidth + moveXDistance - judgeValue + 'px'
} else {
wrapper.style.left = -(currentSwiperItemIndex + 0) * rightWidth + moveXDistance + 'px'
}
}
} else {
if (moveYDistance > 0) {
console.log('往下划')
header.style.height = headerHeight + moveYDistance / 5 + 'px'
} else {
console.log('往上划')
}
// console.log('y', moveYDistance)
}
})
wrapper.addEventListener('touchend', function (e) {
//点击的是左边,并且是菜单展开状态,并且移动距离等于 0那么就收起来
let left = getCss(wrapper, 'left')
if (e.path.includes(leftEl) && left !== 0 && moveXDistance === 0) {
wrapper.style.transition = 'all .2s'
wrapper.style.left = 0
leftEl.style.opacity = 1
resetConfig()
e.stopImmediatePropagation()
e.stopPropagation()
return false
}
if (isCanRightWiping) {
if (!moveXDistance) return
wrapper.style.transition = 'all .2s'
let endTime = Date.now()
let gapTime = endTime - startTime
// 如果
if (Math.abs(moveXDistance) < 20) {
gapTime = 1000
}
if (Math.abs(moveXDistance) > (width / 3)) {
gapTime = 100
}
// console.log('是否向左划',isDrawRight)
if (gapTime < 150) {
// console.log('小于500', currentIndex)
if (isDrawRight) {
// console.log('往左划');
wrapper.style.left = -rightWidth + 'px'
leftEl.style.opacity = 0.5
} else {
wrapper.style.left = 0
leftEl.style.opacity = 1
}
} else {
if (currentSwiperItemIndex === 1) {
wrapper.style.left = -rightWidth + 'px'
} else {
wrapper.style.left = 0
}
}
resetConfig()
isNeedCheck = true
return
} else {
header.style.transition = 'all .3s'
header.style.height = headerHeight + 'px'
resetConfig()
}
})
leftEl.addEventListener('scroll', function () {
if (leftEl.scrollTop > indicatorCtnOffsetTop) {
indicatorCtn.classList.add('fixed')
} else {
indicatorCtn.classList.remove('fixed')
}
})
function resetConfig() {
isCanDownWiping = false
isCanRightWiping = false
isNeedCheck = true
moveXDistance = 0
moveYDistance = 0
}
function checkDirection() {
if (!isNeedCheck) {
// console.log('不需要检测了')
return
}
if (Math.abs(moveXDistance) > judgeValue || Math.abs(moveYDistance) > judgeValue) {
//X 除以 Y
let angle = (Math.abs(moveXDistance) * 10) / (Math.abs(moveYDistance) * 10)
if (angle > 0.7 && angle < 1.3) {
isNeedCheck = false
return
}
// console.log('x------------', moveXDistance)
// console.log('y------------', moveYDistance)
// console.log('角度------------', angle)
if (angle < 0.6) {
//上下划
isCanRightWiping = false
isNeedCheck = false
return
}
if (angle > 5) {
//左右划
isCanRightWiping = true
isNeedCheck = false
return
}
}
}
}()
!function () {
let tabsCtn = document.querySelector('.tabs-ctn')
let tabs = document.querySelector('.tabs')
let indicator = document.querySelector('.indicator')
let tabsTextCtn = document.querySelector('.tabs-text-ctn')
tabsCtn.style.height = getCss(tabs.children[0], 'height') + 'px'
let startLocationX = 0
let startLocationY = 0
let lastLocationX = 0
let lastLocationY = 0
let moveXDistance = 0
let moveYDistance = 0
let judgeValue = 20
let startTime
let currentSwiperItemIndex
let isDrawRight
let isCanRightWiping = false
let isCanDownWiping = false
let isNeedCheck = true
let width = document.body.clientWidth
tabs.addEventListener('touchstart', function (e) {
tabs.style.transition = 'none'
indicator.style.transition = 'none'
let left = getCss(tabs, 'left')
if (Math.abs(left) === 0) {
currentSwiperItemIndex = 0
} else if (Math.abs(left) === width) {
currentSwiperItemIndex = 1
} else {
currentSwiperItemIndex = 2
}
startLocationX = e.touches[0].pageX
startLocationY = e.touches[0].pageY
startTime = Date.now()
})
tabs.addEventListener('touchmove', function (e) {
lastLocationX = e.touches[0].pageX
lastLocationY = e.touches[0].pageY
moveXDistance = lastLocationX - startLocationX
moveYDistance = lastLocationY - startLocationY
isDrawRight = moveXDistance < 0
checkDirection()
if (isCanRightWiping) {
if (currentSwiperItemIndex === tabs.children.length - 1 && isDrawRight) {
return
}
e.stopImmediatePropagation()
e.stopPropagation()
if (isDrawRight) {
indicator.style.marginLeft = (1.5 + (currentSwiperItemIndex + 0) * 33 + Math.abs(moveXDistance) / width / 3 * 100) + '%'
tabs.style.left = -(currentSwiperItemIndex + 0) * width + moveXDistance + judgeValue + 'px'
} else {
if (currentSwiperItemIndex === 0) {
return tabs.style.left = 0
}
let marginLeft = (1.5 + (currentSwiperItemIndex + 0) * 33 - Math.abs(moveXDistance) / width / 3 * 100)
if (marginLeft > 1.5) {
indicator.style.marginLeft = marginLeft + '%'
} else {
indicator.style.marginLeft = '1.5%'
}
tabs.style.left = -(currentSwiperItemIndex + 0) * width + moveXDistance - judgeValue + 'px'
}
}
})
tabs.addEventListener('touchend', function (e) {
if (isCanRightWiping) {
if (currentSwiperItemIndex === tabs.children.length - 1 && isDrawRight) {
return
}
e.stopImmediatePropagation()
e.stopPropagation()
if (!moveXDistance) return
tabs.style.transition = 'all .3s'
indicator.style.transition = 'all .3s'
let endTime = Date.now()
let gapTime = endTime - startTime
// 如果
if (Math.abs(moveXDistance) < 20) {
gapTime = 1000
}
if (Math.abs(moveXDistance) > (width / 3)) {
gapTime = 100
}
if (gapTime < 150) {
// console.log('小于500', currentIndex)
if (isDrawRight) {
indicator.style.marginLeft = 1.5 + (currentSwiperItemIndex + 1) * 33 + '%'
console.log('往左划')
if (currentSwiperItemIndex === tabs.children.length - 1) {
tabs.style.left = -(tabs.children.length - 1) * width + 'px'
return
}
for (let item of tabsTextCtn.children) {
item.classList.remove('active')
}
tabsTextCtn.children[currentSwiperItemIndex + 1].classList.add('active')
tabs.style.left = -(currentSwiperItemIndex + 1) * width + 'px'
tabsCtn.style.height = getCss(tabs.children[currentSwiperItemIndex + 1], 'height') + 'px'
} else {
let marginLeft = 1.5 + (currentSwiperItemIndex - 1) * 33
if (marginLeft > 1.5) {
indicator.style.marginLeft = marginLeft + '%'
} else {
indicator.style.marginLeft = '1.5%'
}
console.log('往右划')
if (currentSwiperItemIndex === 0) {
return tabs.style.left = 0
}
for (let item of tabsTextCtn.children) {
item.classList.remove('active')
}
tabsTextCtn.children[currentSwiperItemIndex - 1].classList.add('active')
tabs.style.left = -(currentSwiperItemIndex - 1) * width + 'px'
tabsCtn.style.height = getCss(tabs.children[currentSwiperItemIndex - 1], 'height') + 'px'
}
} else {
tabs.style.left = -(currentSwiperItemIndex) * width + 'px'
indicator.style.marginLeft = 1.5 + currentSwiperItemIndex * 33 + '%'
}
} else {
isNeedCheck = true
}
resetConfig()
})
for (let i = 0; i < tabsTextCtn.children.length; i++) {
let textEl = tabsTextCtn.children[i]
textEl.addEventListener('click', function () {
indicator.style.marginLeft = 1.5 + i * 33 + '%'
tabs.style.transition = 'all .3s'
tabs.style.left = -i * width + 'px'
})
}
function resetConfig() {
isCanDownWiping = false
isCanRightWiping = false
isNeedCheck = true
moveXDistance = 0
moveYDistance = 0
}
function checkDirection() {
if (!isNeedCheck) {
// console.log('不需要检测了')
return
}
if (Math.abs(moveXDistance) > judgeValue || Math.abs(moveYDistance) > judgeValue) {
//X 除以 Y
let angle = (Math.abs(moveXDistance) * 10) / (Math.abs(moveYDistance) * 10)
// console.log(angle);
if (angle > 0.7 && angle < 1.3) {
isNeedCheck = false
return
}
// console.log('x------------', moveXDistance)
// console.log('y------------', moveYDistance)
// console.log('角度------------', angle)
if (angle < 0.6) {
//上下划
isCanDownWiping = true
isCanRightWiping = false
isNeedCheck = false
return
}
if (angle > 5) {
//左右划
isCanDownWiping = false
isCanRightWiping = true
isNeedCheck = false
return
}
}
}
}()
function getCss(curEle, attr) {
var val = null, reg = null
if ("getComputedStyle" in window) {
val = window.getComputedStyle(curEle, null)[attr]
} else { //ie6~8不支持上面属性
//不兼容
if (attr === "opacity") {
val = curEle.currentStyle["filter"] //'alpha(opacity=12,345)'
reg = /^alphaopacity=(\d+(?:\.\d+)?)opacity=(\d+(?:\.\d+)?)$/i
val = reg.test(val) ? reg.exec(val)[1] / 100 : 1
} else {
val = curEle.currentStyle[attr]
}
}
reg = /^(-?\d+(\.\d)?)(px|pt|em|rem)?$/i
return reg.test(val) ? parseFloat(val) : val
}
this.serviceEl = document.querySelector('.service')
this.serviceHeight = this.getCss(this.serviceEl, 'height')
this.serviceEl.style.height = this.serviceHeight + 'px'
},
computed: {},
methods: {
toggleService() {
console.log(this.serviceEl.style.height)
if (this.serviceEl.style.height === this.serviceHeight + 'px') {
this.serviceEl.style.height = 0
}else {
this.serviceEl.style.height = this.serviceHeight + 'px'
}
}
}
}
</script>
<style scoped lang='scss'>
$left-bg-color: #333;
$right-bg-color: #2e3244;
.Me {
font-size: 1.6rem;
width: 100%;
height: 100%;
overflow: hidden;
.wrapper {
position: relative;
display: flex;
width: 100%;
height: 100%;
.left {
left: 0;
top: 0;
position: absolute;
height: 100%;
width: 100%;
background: $left-bg-color;
overflow-y: scroll;
header {
height: 150px;
/* background-image: url('./imgs/header2.jpg'); */
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: 20px;
img {
border-radius: 50%;
padding: 5px;
background: #524a4a;
height: 20px;
width: 20px;
&:nth-child(1) {
transform: rotate(180deg);
}
}
}
.detail {
background: $left-bg-color;
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: 5px;
border-radius: 50%;
width: 80px;
height: 80px;
}
.my-buttons {
div {
display: flex;
align-items: center;
float: left;
border-radius: 2px;
background: #676767;
margin-right: 5px;
img {
padding: 6px;
height: 20px;
}
span {
color: #cdcdcd;
}
}
}
}
.description {
color: white;
transform: translateY(-20px);
.number {
padding-bottom: 10px;
border-bottom: 1px solid gray;
.jrtt {
float: right;
img {
height: 10px;
width: 10px;
}
span {
margin: 0 5px;
}
}
}
.info {
display: flex;
align-items: center;
div {
display: flex;
align-items: center;
float: left;
border-radius: 2px;
background: #676767;
margin-right: 5px;
padding: 2px 4px;
img {
height: 10px;
margin-right: 3px;
}
span {
color: #cdcdcd;
}
}
}
.heat {
span {
margin-right: 10px;
}
}
}
}
.tabs-ctn {
height: 100%;
width: 100%;
overflow: hidden;
}
.tabs {
left: 0;
transition: all 0.3s ease 0s;
height: 100%;
width: 100%;
position: relative;
}
.tab {
left: 0;
top: 0;
position: absolute;
width: 100%;
background: red;
overflow-y: scroll;
}
.tab:nth-child(2) {
left: 100%;
background: gold;
}
.tab:nth-child(3) {
left: 200%;
background: blue;
}
.indicator-ctn {
top: 0;
left: 0;
right: 0;
z-index: 999;
background: #333;
}
.indicator-ctn.fixed {
position: fixed;
}
.indicator {
height: 2px;
background: gold;
width: 30%;
margin-left: 1.5%;
transition: all .3s;
}
.tabs-text-ctn {
height: 40px;
display: flex;
justify-content: space-around;
align-items: center;
color: gray;
}
.tab-text.active {
color: white;
}
}
.right {
top: 0;
left: 100%;
position: absolute;
height: 100%;
width: 70%;
color: white;
background: $right-bg-color;
ul {
height: 100%;
overflow: auto;
padding: 0;
.line {
height: 1px;
background: #cccccc;
opacity: .1;
margin: 5px 20px;
}
.service {
transition: all .3s;
overflow: hidden;
}
li {
background: $right-bg-color;
padding: 20px;
list-style: none;
display: flex;
align-items: center;
&:active {
background: #454b65;
}
img {
height: 30px;
width: 30px;
margin-right: 20px;
}
&.exception {
justify-content: space-between;
.triangle {
transform: translateY(3px);
width: 0;
height: 0;
border-top: 7px solid #cccccc;
border-right: 7px solid transparent;
border-bottom: 7px solid transparent;
border-left: 7px solid transparent;
}
}
}
}
}
}
}
</style>