Commit 840efd1e authored by caimeng's avatar caimeng

修复首页滚动闪屏的问题,调整我的点击去登录页回不来的问题

parent e2d1ab75
......@@ -21,6 +21,12 @@
improve-new-ddh-app:是典当基础上通过webview加载h5贷超(在new-ddh-app上优化的分支,添加启动页)
new-dev:弃用
### 资源
APP当中的资源文件在【远益典当】账户的OSS里面
资源Bucket名字:【uni-app-ddh】
资源Bucket域名:https://ddh.yyhock.com/*
### 其他
参考:
......
......@@ -118,8 +118,12 @@
{
"path": "pages/login/login",
"style": {
"navigationStyle": "custom",
"enablePullDownRefresh": false,
"navigationBarTitleText": "登录"
"navigationBarTitleText": "登录",
"app-plus": {
"softinputMode": "adjustResize"
}
}
},
{
......
.i-page{
.i-page {
width: 100%;
height: calc(100vh-120rpx);
// min-height: 1624rpx;
background: #F7FAFF;
.i-header{
position: sticky;
top:0;
z-index:9988;
padding-top:98rpx;
width: 100%;
height: 88rpx;
background: #FFFFFF;
font-family: PingFangSC, PingFang SC;
font-weight: 500;
font-size: 36rpx;
color: #333333;
line-height: 88rpx;
text-align: center;
font-style: normal;
box-sizing: border-box;
background: #F7FAFF url('https://ddh.yyhock.com/ddhMall/index-bg.png') 0 0 no-repeat;
background-size: 100% 505rpx;
box-sizing: border-box;
padding-top: 176rpx;
// 头部
.i-header {
position: fixed;
left: 0;
top: 0;
z-index: 1000;
width: 100vw;
min-height: 176rpx;
height: auto;
background: #F7FAFF url('https://ddh.yyhock.com/ddhMall/index-bg.png') 0 0 no-repeat;
background-size: 100% 505rpx;
// 顶部标题
.i-title {
width: 100%;
height: 176rpx;
background: transparent;
line-height: 88rpx;
text-align: center;
padding-top: 88rpx;
box-sizing: border-box;
text {
font-weight: 500;
font-size: 36rpx;
color: #333333;
}
}
}
.i-boxs{
.i-banner{
margin: 20rpx 22rpx 32rpx;
// 用来判断吸顶的元素
#box {
position: absolute;
left: 0;
top: 580rpx;
width: 100vw;
height: 1rpx;
}
// 商品tab
.hot-tab {
margin: 0 36rpx 16rpx;
height: 86rpx;
display: flex;
align-items: center;
font-size: 28rpx;
line-height: 40rpx;
.hot-header-text {
width: 160rpx;
display: flex;
font-family: PingFangSC-Regular, PingFang SC;
color: #999999;
text-align: center;
.hot-ative {
position: relative;
z-index: 1;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
font-size: 30rpx;
color: #333333;
}
.hot-ative::after {
content: '';
position: absolute;
top: 30%;
left: 0;
width: 100%;
height: 6px;
/* 背景色的高度 */
background-color: #CDE0FE;
/* 背景色 */
z-index: -1
}
.hot-icon-show {
margin-top: 10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active-show.png') 0 0 no-repeat;
background-size: 100%;
}
.hot-icon-show-down {
margin-top: 10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active-show-down.png') 0 0 no-repeat;
background-size: 100%;
}
}
.hot-icon {
margin-top: 36rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active.png') 0 0 no-repeat;
background-size: 100%;
}
.hot-show {
// flex:1;
width: 160rpx;
display: flex;
color: #999999;
line-height: 90rpx;
text-align: center;
}
}
// banner 位置
.i-banner {
margin: 20rpx 22rpx 0;
width: 706rpx;
height: 359rpx;
.swiper-item-i {
width: 706rpx;
height: 359rpx;
.swiper-item-i{
.banner-item {
width: 706rpx;
height: 359rpx;
.banner-item{
width: 706rpx;
height: 359rpx;
background-size: 690rpx 359rpx;
}
background-size: 690rpx 359rpx;
}
}
.i-list{
margin: 0 50rpx;
display: flex;
flex-wrap: wrap;
.mian-item{
margin-right: 67rpx;
.item-img{
margin: 0 16rpx;
width: 80rpx;
height: 80rpx;
background-size: 100%;
}
.item-text{
height: 40rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 28rpx;
color: #333333;
line-height: 40rpx;
text-align: center;
font-style: normal;
}
}
// 金刚位
.i-list {
margin: 0 50rpx;
display: flex;
flex-wrap: wrap;
height: 200rpx;
box-sizing: border-box;
padding-top: 30rpx;
.mian-item {
margin-right: 67rpx;
.item-img {
margin: 0 16rpx;
width: 80rpx;
height: 80rpx;
background-size: 100%;
}
.mian-item:nth-of-type(4n){
margin-right:0;
.item-text {
height: 40rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 28rpx;
color: #333333;
line-height: 40rpx;
text-align: center;
font-style: normal;
}
}
.i-malll{
// height: 600rpx;
.hot-tab{
margin:50rpx 36rpx 16rpx;
height: 86rpx;
.mian-item:nth-of-type(4n) {
margin-right: 0;
}
}
.i-boxs {
.box-at-home {
background: #F7FAFF;
.main-box {
display: flex;
flex-wrap: wrap;
align-items: center;
font-size: 28rpx;
line-height: 40rpx;
.hot-header-text{
width: 160rpx;
display: flex;
font-family: PingFangSC-Regular, PingFang SC;
color: #999999;
text-align: center;
.hot-ative{
position: relative;
z-index: 1;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
font-size: 30rpx;
color: #333333;
}
.hot-ative::after{
content: '';
position: absolute;
top:30%;
left: 0;
width: 100%;
height: 6px; /* 背景色的高度 */
background-color: #CDE0FE; /* 背景色 */
z-index: -1
}
.hot-icon-show{
margin-top:10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active-show.png') 0 0 no-repeat;
background-size: 100%;
}
.hot-icon-show-down{
margin-top:10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active-show-down.png') 0 0 no-repeat;
background-size: 100%;
}
}
.hot-icon{
margin-top:36rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('../../static/img/hot-active.png') 0 0 no-repeat;
background-size: 100%;
}
.hot-show{
// flex:1;
width: 160rpx;
display: flex;
color:#999999;
line-height:90rpx;
text-align: center;
}
}
.hot-fixed-show{
position: fixed;
top:0;
left: 0;
width: 100%;
z-index: 999;
height: 86rpx;
background:#FFFFFF;
font-size: 28rpx;
line-height: 40rpx;
margin-bottom: 220rpx;
.hot-text{
padding-top:108rpx;
width: 100%;
height:98rpx;
margin: 0 30rpx;
.box-item {
margin-bottom: 24rpx;
width: 333rpx;
height: 426rpx;
background: #FFFFFF;
font-family: PingFangSC, PingFang SC;
font-weight: 500;
font-size: 36rpx;
color: #333333;
line-height: 50rpx;
text-align: center;
font-style: normal;
}
.hot-tab-fixed{
height: 86rpx;
display: flex;
align-items: center;
background:#FFFFFF;
font-size: 28rpx;
line-height: 40rpx;
.hot-text{
width: 100%;
height:98rpx;
background: #FFFFFF;
font-family: PingFangSC, PingFang SC;
font-weight: 500;
font-size: 36rpx;
color: #333333;
line-height: 50rpx;
text-align: center;
font-style: normal;
}
.hot-header-text{
margin-left:30rpx;
width: 160rpx;
box-shadow: 0rpx 0rpx 10rpx 0rpx rgba(232, 232, 232, 0.49);
border-radius: 10rpx;
.item-top {
display: flex;
font-family: PingFangSC-Regular, PingFang SC;
color: #999999;
text-align: center;
.hot-ative{
position: relative;
z-index: 1;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
font-size: 30rpx;
color: #333333;
width: 333rpx;
height: 272rpx;
position: relative;
.top-img {
width: 333rpx;
height: 272rpx;
background-size: 333rpx 272rpx;
border-radius: 10rpx;
}
.hot-ative::after{
content: '';
.top-icon {
position: absolute;
top:30%;
left: 0;
width: 100%;
height: 6px; /* 背景色的高度 */
background-color: #CDE0FE; /* 背景色 */
z-index: -1
}
.hot-icon-show{
margin-top:10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('https://ddh.yyhock.com/ddhMall/hot-active-show.png') 0 0 no-repeat;
background-size: 100%;
// position: sticky;
top: 0;
// right:0;
margin-left: 215rpx;
// z-index:99;
display: inline-block;
width: 118rpx;
height: 110rpx;
background: url('https://ddh.yyhock.com/ddhMall/goods-sale.png') 0 0 no-repeat;
background-size: 118rpx 110rpx;
}
.hot-icon-show-down{
margin-top:10rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('https://ddh.yyhock.com/ddhMall/hot-active-show-down.png') 0 0 no-repeat;
background-size: 100%;
}
}
.hot-icon{
margin-top:36rpx;
margin-left: 10rpx;
width: 20rpx;
height: 20rpx;
background: url('https://ddh.yyhock.com/ddhMall/hot-active.png') 0 0 no-repeat;
background-size: 100%;
}
.hot-show{
margin-left:36rpx;
width: 160rpx;
display: flex;
color:#999999;
line-height:90rpx;
text-align: center;
}
}
}
.box-at-home{
background:#F7FAFF ;
.main-box{
display:flex;
flex-wrap: wrap;
align-items: center;
margin:0 30rpx;
.box-item{
margin-bottom:24rpx;
width: 333rpx;
height: 426rpx;
background: #FFFFFF;
box-shadow: 0rpx 0rpx 10rpx 0rpx rgba(232,232,232,0.49);
border-radius: 10rpx;
.item-top{
.item-footer {
padding: 9rpx 16rpx 21rpx 0rpx;
.footer-des {
width: 260rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 26rpx;
color: #333333;
line-height: 37rpx;
text-align: left;
font-style: normal;
white-space: nowrap;
/* 确保文本在一行内显示 */
overflow: hidden;
/* 隐藏超出容器的内容 */
text-overflow: ellipsis;
/* 使用省略号表示被截断的文本 */
word-break: break-all;
/* 允许在单词内换行 */
}
.footer-box {
display: flex;
margin: 9rpx 0 16rpx;
.box-num {
display: flex;
width: 333rpx;
height: 272rpx;
position: relative;
.top-img{
width: 333rpx;
height: 272rpx;
background-size: 333rpx 272rpx;
border-radius: 10rpx;
}
.top-icon{
position: absolute;
// position: sticky;
top:0;
// right:0;
margin-left: 215rpx;
// z-index:99;
display: inline-block;
width:118rpx;
height: 110rpx;
background: url('https://ddh.yyhock.com/ddhMall/goods-sale.png') 0 0 no-repeat;
background-size:118rpx 110rpx ;
}
}
.item-footer{
padding: 9rpx 16rpx 21rpx 0rpx;
.footer-des{
width: 260rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 26rpx;
color: #333333;
line-height: 37rpx;
text-align: left;
font-style: normal;
white-space: nowrap; /* 确保文本在一行内显示 */
overflow: hidden; /* 隐藏超出容器的内容 */
text-overflow: ellipsis; /* 使用省略号表示被截断的文本 */
word-break: break-all; /* 允许在单词内换行 */
}
.footer-box{
display: flex;
margin:9rpx 0 16rpx;
.box-num{
display: flex;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 28rpx;
color: #FC4D3E;
line-height: 28rpx;
text-align: left;
font-style: normal;
.num-icon{
margin-top:4rpx;
font-size: 20rpx;
}
}
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 28rpx;
color: #FC4D3E;
line-height: 28rpx;
text-align: left;
font-style: normal;
.num-icon {
margin-top: 4rpx;
font-size: 20rpx;
}
.footer-line{
display: flex;
align-items: center;
justify-content: space-between;
.box-btn{
width: 76rpx;
height: 38rpx;
border-radius: 5rpx;
border: 1rpx solid #2263E6;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 20rpx;
color: #2263E6;
line-height: 38rpx;
text-align: center;
font-style: normal;
}
.box-last{
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 20rpx;
color: #999999;
line-height: 38rpx;
text-align: right;
font-style: normal;
}
}
}
}
:nth-child(2n){
margin-left: 24rpx;
.footer-line {
display: flex;
align-items: center;
justify-content: space-between;
.box-btn {
width: 76rpx;
height: 38rpx;
border-radius: 5rpx;
border: 1rpx solid #2263E6;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 20rpx;
color: #2263E6;
line-height: 38rpx;
text-align: center;
font-style: normal;
}
.box-last {
font-family: PingFangSC, PingFang SC;
font-weight: 400;
font-size: 20rpx;
color: #999999;
line-height: 38rpx;
text-align: right;
font-style: normal;
}
}
}
}
:nth-child(2n) {
margin-left: 24rpx;
}
}
}
}
}
\ No newline at end of file
<template>
<view class="i-page">
<view class='i-header' v-show='isFixed != true'>
<text>多典花</text>
<!-- 默认样式 -->
<view class='i-header'>
<view class="i-title">
<text>多典花</text>
</view>
</view>
<!-- 吸顶样式 -->
<view v-if="isFixed" :class="[isFixed ? 'i-header-fixed' : '', 'i-header']">
<view class="i-title">
<text>多典花</text>
</view>
<view v-if="hotList && hotList.length" class="hot-tab">
<view :class="hotIndex == item.id ? 'hot-header-text' : 'hot-show'" v-for="item in hotList"
:key='item.id'>
<view class='hot-ative' @click="hotShow(item)">{{ item.title }}</view>
<view v-show="hotIndex != item.id" class='hot-icon'></view>
<view v-show='hotIndex == item.id' :class="showUP == false ? 'hot-icon-show-down' : 'hot-icon-show'"
@click="goUP(item.id)">
</view>
</view>
</view>
</view>
<!-- 用来判断高度的元素 -->
<view id="box"></view>
<view v-if='index !== null' class='i-boxs'>
<!-- Banner 位 -->
<view v-if="index['bannerList']" class='i-banner'>
......@@ -26,9 +51,10 @@
<view class="i-malll">
<!-- 根据滚动条的高度显示隐藏内容 -->
<view v-if='isFixed != true' class="hot-tab">
<view :class="hotIndex == item.id ? 'hot-header-text' : 'hot-show'" v-for="item in hotList"
<view class="hot-tab">
<view v-for="item in hotList" :class="hotIndex == item.id ? 'hot-header-text' : 'hot-show'"
:key='item.id'>
<view class='hot-ative' @click="hotShow(item)">{{ item.title }}</view>
<view v-show="hotIndex != item.id" class='hot-icon'></view>
......@@ -37,26 +63,14 @@
</view>
</view>
</view>
<view v-else class="hot-fixed-show">
<view class="hot-text">多典花</view>
<view class="hot-tab-fixed">
<view :class="hotIndex == item.id ? 'hot-header-text' : 'hot-show'" v-for="item in hotList"
:key='item.id'>
<view class='hot-ative' @click="hotShow(item)">{{ item.title }}</view>
<view v-show="hotIndex != item.id" class='hot-icon'></view>
<view v-show='hotIndex == item.id'
:class="showUP == false ? 'hot-icon-show-down' : 'hot-icon-show'"
@click="goUP(item.id)">
</view>
</view>
</view>
</view>
<!-- 商品列表 -->
<scroll-view class='box-at-home' scroll-y="true" refresher-default-style="none"
@scrolltoupper="toupperTop" @scrolltolower="lowerMore">
<view class='main-box' v-show="IndexList && IndexList.length > 0">
<view class='box-item' v-for="(item,index) in IndexList" :key="index" @click="goDetail(item)">
<view class='box-item' v-for="(item, index) in IndexList" :key="index" @click="goDetail(item)">
<view class='item-top'>
<image :src="item.goodsImage" class='top-img'></image>
<i class='top-icon'></i>
......@@ -123,11 +137,15 @@ export default {
appUpgeadeObj: {},
isFirstShow: true
// 吸顶
}
},
onPageScroll(e) {
this.scrollTop = e.scrollTop;
if (e.scrollTop > 220) {
console.log(e.scrollTop, this.Topdistance, '高度')
if (e.scrollTop > this.Topdistance) {
this.isFixed = true;
} else {
this.isFixed = false;
......@@ -135,28 +153,53 @@ export default {
},
async onLoad() {
this.isFirstShow = uni.getStorageSync('isFirstShow')
// 初始化首页数据
await ininIndex()
await this.searchGood();
await this.getAppVersion()
uni.pageScrollTo({
scrollTop: 0,
duration: 0
})
setTimeout(() => {
this.GetTop() // 获取元素距离顶部的距离
}, 1000)
await this.getAppVersion()
},
async onShow() {
// 初始化首页数据
ininIndex()
// 显示隐藏tabBar
switchShowTabbar()
// 初始化首页数据
await ininIndex()
await this.searchGood();
// 首页流量埋点
this.buryingPoint('app:index_page_view')
await this.initAjax();
},
methods: {
// 初始化网络请求
async initAjax() {
await uni.$util.getNetworkException([
this.init(),
this.searchGood()
])
// 获取元素距离顶部的距离
GetTop() {
var _this = this
uni.getSystemInfo({
success: (res) => {
const query = uni.createSelectorQuery().in(this);
query.select("#box").boundingClientRect((data) => {
console.log("得到布局位置信息" + JSON.stringify(data));
console.log("节点离页面顶部的距离为" + data.top);
_this.Topdistance = data.top
console.log(_this.Topdistance, '元素的高度')
}).exec();
},
fail: (res) => {
}
})
},
// 跳转
jump(item, index, type) {
......@@ -229,18 +272,8 @@ export default {
pauseClick(data) {
this.appUpgeadeObj.downloadUrl = ''
},
// 初始Banner位和金刚位
async init() {
try {
const res = await this.$request('/pawn/index', 'GET');
if (res.success) uni.setStorageSync('dataIndex', JSON.stringify(res.result))
this.index = res.result
} catch (err) {
console.log(err, '请求出错')
}
},
goDetail(item) {
goDetail(item) {
// 首页流量埋点
this.buryingPoint('app:index_product_click')
uni.navigateTo({
......@@ -326,6 +359,8 @@ export default {
}
},
toupperTop: function (e) {
console.log(e, '到顶了');
},
......
.login-page{
width: 100%;
.login-page {
position: relative;
width: 100vw;
height: 100vh;
min-height: 100vh;
background: linear-gradient( 180deg, #FFFFFF 0%, #FFFFFF 100%);
.login-top{
background: linear-gradient(180deg, #FFFFFF 0%, #FFFFFF 100%);
.login-back {
position: absolute;
left: 60rpx;
top: 107rpx;
display: block;
width: 42rpx;
height: 42rpx;
}
.login-top {
width: 100%;
height: 505rpx;
background: url('https://ddh.yyhock.com/appStatic/my-bg.png') 0 0 no-repeat;
background-size: 100% 505rpx;
.top-icon{
margin:277rpx 325rpx 19rpx;
.top-icon {
margin: 277rpx 325rpx 19rpx;
width: 100rpx;
height: 100rpx;
background-size: 100%;
}
.top-name{
.top-name {
height: 70rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
......@@ -27,16 +40,19 @@
text-transform: none;
}
}
.login-main{
margin:83rpx 60rpx 51rpx;
.main-mobile{
.login-main {
margin: 83rpx 60rpx 51rpx;
.main-mobile {
width: 630rpx;
height: 100rpx;
background: #FFFFFF;
border-radius: 16rpx;
border: 1rpx solid #999999;
.login-m-mobile{
padding-left:28rpx;
.login-m-mobile {
padding-left: 28rpx;
height: 100rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
......@@ -48,12 +64,14 @@
text-transform: none;
}
}
.login-m-send{
margin-top:50rpx;
.login-m-send {
margin-top: 50rpx;
display: flex;
.send-value{
padding-left:28rpx;
flex:1;
.send-value {
padding-left: 28rpx;
flex: 1;
height: 100rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
......@@ -65,9 +83,10 @@
font-style: normal;
text-transform: none;
}
.send-text{
.send-text {
padding-right: 24rpx;
padding-left:12rpx;
padding-left: 12rpx;
height: 100rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 500;
......@@ -78,8 +97,9 @@
font-style: normal;
text-transform: none;
}
.mobileCode-min{
padding-left:12rpx;
.mobileCode-min {
padding-left: 12rpx;
padding-right: 24rpx;
// width: 180rpx;
height: 100rpx;
......@@ -93,13 +113,14 @@
text-transform: none;
}
}
}
.login-btn{
.login-btn {
margin: 0 60rpx;
width: 630rpx;
height: 100rpx;
background: linear-gradient( 137deg, #3877F5 0%, #5690FA 100%);
background: linear-gradient(137deg, #3877F5 0%, #5690FA 100%);
border-radius: 14rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
......@@ -110,25 +131,31 @@
font-style: normal;
text-transform: none;
}
.login-footer{
margin-top:15rpx;
.login-footer {
margin-top: 25rpx;
display: flex;
align-items: center;
margin-left:88rpx;
.footer-icon{
width: 24rpx;
height: 24rpx;
margin-left: 88rpx;
.f-checkbox {
width: 30rpx;
height: 30rpx;
}
.footer-icon {
background: url('https://ddh.yyhock.com/appStatic/login-null.png') 0 0 no-repeat;
background-size: 100%;
}
.footer-click{
width: 24rpx;
height: 24rpx;
.footer-click {
background: url('https://ddh.yyhock.com/appStatic/login-click.png') 0 0 no-repeat;
background-size: 100%;
}
.footer-text{
margin-left:10rpx;
.footer-text {
margin-left: 10rpx;
height: 33rpx;
font-family: PingFangSC, PingFang SC;
font-weight: 400;
......@@ -138,8 +165,9 @@
text-align: left;
font-style: normal;
text-transform: none;
.link{
color:#2263E6;
.link {
color: #2263E6;
}
}
}
......
<template>
<view class='login-page'>
<image class="login-back" @click="GoBack" src='https://ddh.yyhock.com/ddhMall/login-back.png'></image>
<view class='login-top'>
<image class='top-icon' src='https://ddh.yyhock.com/appStatic/login-logo.png'></image>
<view class='top-name'>多典花</view>
......@@ -19,7 +22,7 @@
</view>
<view class='login-btn' @click="loginBtn">登录</view>
<view class='login-footer'>
<view :class="clickStatus ? 'footer-click' : 'footer-icon'" @click="btnIcon"></view>
<view :class="clickStatus ? 'f-checkbox footer-click' : 'f-checkbox footer-icon'" @click="btnIcon"></view>
<view v-if="protocolf" class='footer-text'>
<text>我已阅读并同意</text>
<uni-link class="link" :href="protocolf.protocolUrl">《注册协议》</uni-link>
......@@ -53,6 +56,9 @@ export default {
this.buryingPoint('app:login_pageView')
},
methods: {
GoBack(){
this.Back()
},
async init() {
const $App_Setting = uni.getStorageSync("APP-SETTING")
if ($App_Setting) {
......@@ -72,7 +78,6 @@ export default {
goPro(type) {
if (type == '1') {
const { protocolUrl, protocolName } = this.protocolf
console.log(this.protocolf, '99')
const items = {
name: protocolName,
url: protocolUrl
......@@ -82,7 +87,6 @@ export default {
})
} else {
const { protocolUrl, protocolName } = this.protocols
console.log(this.protocols, '88')
const items = {
name: protocolName,
url: protocolUrl
......@@ -198,7 +202,6 @@ export default {
const { deviceId, token } = res.result
const cacheData = Object.assign({}, res.result, { mobile: self.mobile })
console.log(cacheData, '返回的结果')
uni.setStorageSync('user_info_obj', JSON.stringify(cacheData));
......
......@@ -13,9 +13,8 @@
background-size: 100% 505rpx;
.my-header {
display: flex;
margin-bottom: 66rpx;
.header-img {
margin-top: 128rpx;
margin-left: 28rpx;
......@@ -53,7 +52,7 @@
}
.my-line {
margin: 66rpx 30rpx 0;
margin: 0 30rpx 20rpx;
display: flex;
align-items: center;
height: 144rpx;
......@@ -102,7 +101,7 @@
}
.my-box-s {
margin: 19rpx 30rpx 30rpx;
margin: 0 30rpx 30rpx;
width: 690rpx;
height: 169rpx;
background: #FFFFFF;
......
<template>
<view class='my-page'>
<view class='my-top'>
<view class='my-header'>
<image class='header-img' src='https://ddh.yyhock.com/ddhMall/my-icon.png'></image>
<view class='header-des'>
<view class='des-name' v-if="userTel != ''">{{ userTel }}</view>
<view class='des-name' v-else @click='goLogin'>注册/登录</view>
<view class='des-name' v-else @click='GoLogin'>注册/登录</view>
<view class='des-text'>多典花承诺保护您的信息安全</view>
</view>
</view>
<!-- 我的还款&申请记录 -->
<template v-if="menuBar && menuBar.length > 0">
<view class='my-line'>
<view class='line-left' v-for="item in menuBar" :key="item.id" @click="goBar(item)">
<image class='left-img' :src='item.iconUrl'></image>
<view class='l-text'>{{ item.title }}</view>
<i class='l-go'></i>
<template v-if="isLogin">
<!-- 我的还款&申请记录 -->
<template v-if="menuBar && menuBar.length > 0">
<view class='my-line'>
<view class='line-left' v-for="item in menuBar" :key="item.id" @click="goBar(item)">
<image class='left-img' :src='item.iconUrl'></image>
<view class='l-text'>{{ item.title }}</view>
<i class='l-go'></i>
</view>
</view>
</template>
<!-- 金刚栏位 -->
<template v-if="extMenuBarList && extMenuBarList.length > 0">
<view class='my-box-s'>
<view class='s-con'>
<view class='con-item' @click="goPage(item)" v-for="item in extMenuBarList" :key="item.id">
<image class="item-img" :src="item.iconUrl"></image>
<view class='item-text'>{{ item.title }}</view>
</view>
</view>
</view>
</template>
<!-- 更多服务 -->
<view v-if="menuList && menuList.length > 0" class="my-contain">
<i class='con-top'></i>
<view class='con-box' v-if='menuList && menuList.length > 0'>
<view class="box-line" v-for="item in menuList" @click='goItem(item)' :key="item.id">
<view class='line-item'>
<view class='item-l'>
<image class='l-img' :src='item.iconUrl'></image>
<view class='l-text'>{{ item.title }}</view>
</view>
<view class='item-r'></view>
</view>
</view>
</view>
</view>
</template>
</template>
<template v-else>
<!-- 金刚栏位 -->
<template v-if="extMenuBarList && extMenuBarList.length>0">
<view class='my-box-s'>
<view class='s-con'>
<view class='con-item' @click="goPage(item)" v-for="item in extMenuBarList" :key="item.id">
<image class="item-img" :src="item.iconUrl"></image>
<view class='item-text'>{{ item.title }}</view>
<view class='con-item' @click="GoLogin">
<image class="item-img" src="https://ddh.yyhock.com/ddhMall/my-glance.png"></image>
<view class='item-text'>我的浏览</view>
</view>
<view class='con-item' @click="GoLogin">
<image class="item-img" src="https://ddh.yyhock.com/ddhMall/need-icon.png"></image>
<view class='item-text'>我的需要</view>
</view>
<view class='con-item' @click="GoLogin">
<image class="item-img" src="https://ddh.yyhock.com/ddhMall/my-attentiion.png"></image>
<view class='item-text'>我的关注</view>
</view>
<view class='con-item' @click="GoLogin">
<image class="item-img" src="https://ddh.yyhock.com/ddhMall/user-icon.png"></image>
<view class='item-text'>意见反馈</view>
</view>
</view>
</view>
</template>
<!-- 更多服务 -->
<view v-if="menuList && menuList.length>0" class="my-contain">
<i class='con-top'></i>
<view class='con-box' v-if='menuList && menuList.length > 0'>
<view class="box-line" v-for="item in menuList" @click='goItem(item)' :key="item.id">
<view class='line-item'>
<view class='item-l'>
<image class='l-img' :src='item.iconUrl'></image>
<view class='l-text'>{{ item.title }}</view>
<!-- 更多服务 -->
<view class="my-contain">
<i class='con-top'></i>
<view class='con-box'>
<view class="box-line">
<view @click="GoLogin" class='line-item'>
<view class='item-l'>
<image class='l-img' src="https://ddh.yyhock.com/appStatic/product.png"></image>
<view class='l-text'>产品列表</view>
</view>
<view class='item-r'></view>
</view>
</view>
<view class="box-line">
<view @click="GoLogin" class='line-item'>
<view class='item-l'>
<image class='l-img' src="https://ddh.yyhock.com/ddhMall/my-tel.png"></image>
<view class='l-text'>帮助中心</view>
</view>
<view class='item-r'></view>
</view>
</view>
<view class="box-line">
<view @click="GoLogin" class='line-item'>
<view class='item-l'>
<image class='l-img' src="https://ddh.yyhock.com/appStatic/setting.png"></image>
<view class='l-text'>设置</view>
</view>
<view class='item-r'></view>
</view>
<view class='item-r'></view>
</view>
</view>
</view>
</view>
</template>
<!-- 联系我们 -->
......@@ -71,24 +136,31 @@
import { switchShowTabbar } from '@/utils/index'
const APP = JSON.parse(uni.getStorageSync('APP-SETTING'));
const H5 = JSON.parse(uni.getStorageSync('H5-SETTING'));
const hasToken = uni.getStorageSync('token') ? true : false;
export default {
data() {
return {
isLogin: hasToken,
userTel: '',
menuList: [],
mobileNum: '',
menuBar: [],
serviceCall:APP.serviceCall,
serviceCall: APP.serviceCall,
serviceCall: '',
extMenuBarList: [],
hFUrl:''
hFUrl: ''
}
},
onLoad() {
this.init()
},
onShow() {
const haveToken = uni.getStorageSync('token')
if (haveToken) this.isLogin = true
else this.isLogin = false
// 显示隐藏tabBar
switchShowTabbar()
this.init()
......@@ -106,13 +178,17 @@ export default {
},
methods: {
// 跳转到登录
GoLogin() {
this.Go('uni:/pages/login/login')
},
// 初始化
init() {
const token = uni.getStorageSync('token')
console.log(token, 'tokens')
if (!token) {
this.userTel = ''
return this.Go('uni:/pages/login/login')
// return this.Go('uni:/pages/login/login')
} else {
this.initMy()
}
......@@ -159,10 +235,6 @@ export default {
this.Go(item.linkUrl)
},
goLogin() {
this.Go('uni:/pages/login/login')
},
goBar(item) {
let newPath
switch (item.title) {
......@@ -212,7 +284,7 @@ export default {
goPhone() {
uni.setStorageSync('telPhone', '1')
uni.makePhoneCall({
phoneNumber:APP.serviceCall//仅为示例
phoneNumber: APP.serviceCall//仅为示例
});
},
......
......@@ -5,12 +5,10 @@
</template>
<script>
import { ininIndex, initSettings, initApp } from '@/utils/index'
import { ininIndex,initIndexGoods, initSettings, initApp } from '@/utils/index'
export default {
async onLoad() {
// 有网络了再弹窗
uni.getNetworkType({
success: async function (res) {
......@@ -24,6 +22,7 @@ export default {
uni.onNetworkStatusChange(async (res) => {
if (res.isConnected) {
await ininIndex()
await initIndexGoods()
await initSettings()
await initApp()
this.init()
......@@ -32,8 +31,10 @@ export default {
await ininIndex()
await initIndexGoods()
await initSettings()
await initApp()
if(uni.getStorageSync('APP-SETTING')) this.init()
},
methods: {
......
......@@ -17,4 +17,8 @@ export default {
async initIndex(data) {
return request('/pawn/index', 'GET', data);
},
/* 初始化首页商品 */
async initIndexGoods(data) {
return request('/pawn/category/getGoodsPage', 'POST', data);
},
}
......@@ -121,6 +121,22 @@ export const ininIndex = async () => {
console.log(err, '初始化')
}
}
// 首页商品列表
export const initIndexGoods = async () => {
try {
const data = {
pageNum: 1,
pageSize: 50,
sort: 'look_sum desc'
}
const { success, result } = await API.initIndexGoods({ ...data })
if (success && result && result.records) uni.setStorageSync('indexGoods', JSON.stringify(result.records))
} catch (err) {
console.log(err, '初始化')
}
}
// 设备信息
export const loadDevice = async () => {
convertPromise('getSystemInfo').then(result => {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment