Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
U
uni-app-ddh-shop
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
zhanhai
uni-app-ddh-shop
Commits
840efd1e
Commit
840efd1e
authored
Nov 13, 2024
by
caimeng
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修复首页滚动闪屏的问题,调整我的点击去登录页回不来的问题
parent
e2d1ab75
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
586 additions
and
454 deletions
+586
-454
README.md
README.md
+6
-0
pages.json
pages.json
+5
-1
index.less
pages/index/index.less
+289
-325
index.vue
pages/index/index.vue
+78
-43
index.less
pages/login/index.less
+67
-39
login.vue
pages/login/login.vue
+7
-4
index.less
pages/my/index.less
+3
-4
index.vue
pages/my/index.vue
+107
-35
index.vue
pages/starPage/index.vue
+4
-3
common.js
server/common.js
+4
-0
index.js
utils/index.js
+16
-0
No files found.
README.md
View file @
840efd1e
...
...
@@ -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/
*
### 其他
参考:
...
...
pages.json
View file @
840efd1e
...
...
@@ -118,8 +118,12 @@
{
"path"
:
"pages/login/login"
,
"style"
:
{
"navigationStyle"
:
"custom"
,
"enablePullDownRefresh"
:
false
,
"navigationBarTitleText"
:
"登录"
"navigationBarTitleText"
:
"登录"
,
"app-plus"
:
{
"softinputMode"
:
"adjustResize"
}
}
},
{
...
...
pages/index/index.less
View file @
840efd1e
.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
pages/index/index.vue
View file @
840efd1e
<
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
,
'到顶了'
);
},
...
...
pages/login/index.less
View file @
840efd1e
.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;
}
}
}
...
...
pages/login/login.vue
View file @
840efd1e
<
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 ? 'f
ooter-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
));
...
...
pages/my/index.less
View file @
840efd1e
...
...
@@ -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;
...
...
pages/my/index.vue
View file @
840efd1e
<
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=
'
g
oLogin'
>
注册/登录
</view>
<view
class=
'des-name'
v-else
@
click=
'
G
oLogin'
>
注册/登录
</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
//仅为示例
});
},
...
...
pages/starPage/index.vue
View file @
840efd1e
...
...
@@ -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
:
{
...
...
server/common.js
View file @
840efd1e
...
...
@@ -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
);
},
}
utils/index.js
View file @
840efd1e
...
...
@@ -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
=>
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment