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
ea87ad53
Commit
ea87ad53
authored
Feb 12, 2025
by
caimeng
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改准备提包
parent
636d269a
Changes
10
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
3952 additions
and
68 deletions
+3952
-68
launch.json
.hbuilderx/launch.json
+1
-1
App.vue
App.vue
+7
-7
data.json
common/city-china/data.json
+3725
-0
api.js
config/api.js
+2
-2
index.vue
pages/index/index.vue
+6
-2
common.js
server/common.js
+60
-12
address.vue
subPackage/address/address.vue
+2
-2
create.vue
subPackage/address/create.vue
+118
-34
order.vue
subPackage/order/order.vue
+29
-6
productDetails.vue
subPackage/productDetails/productDetails.vue
+2
-2
No files found.
.hbuilderx/launch.json
View file @
ea87ad53
...
...
@@ -17,7 +17,7 @@
"type"
:
"uniCloud"
},
{
"playground"
:
"
standard
"
,
"playground"
:
"
custom
"
,
"type"
:
"uni-app:app-android"
},
{
...
...
App.vue
View file @
ea87ad53
...
...
@@ -26,15 +26,15 @@ export default {
const
appStart
=
uni
.
getStorageSync
(
'appStart'
)
if
(
appStart
)
{
//
uni.switchTab({
//
url: "/pages/index/index",
//
success: function () {
//
plus.navigator.closeSplashscreen()
//
}
//
})
uni
.
switchTab
({
url
:
"/pages/index/index"
,
success
:
function
()
{
plus
.
navigator
.
closeSplashscreen
()
}
})
uni
.
redirectTo
({
url
:
"/subPackage/order/
list
"
,
url
:
"/subPackage/order/
order
"
,
success
:
function
()
{
plus
.
navigator
.
closeSplashscreen
()
}
...
...
common/city-china/data.json
0 → 100644
View file @
ea87ad53
This diff is collapsed.
Click to expand it.
config/api.js
View file @
ea87ad53
...
...
@@ -20,7 +20,7 @@ const BASE = {
h5
:
'https://ddang-hhym-h5-g.rockstect.cn/index.html'
},
prod
:
{
common
:
"https://
api.yyhock
.com"
,
common
:
"https://
portal.rockstect
.com"
,
event
:
'https://event.jqtianxia.com'
,
h5
:
'https://ddang-hhym-h5.rockstect.com/v1.0.0.html'
}
...
...
@@ -38,7 +38,7 @@ let env = process.env.VUE_APP_BASE_NODE_ENV
*/
// #ifdef APP-PLUS
env
=
"
stest
"
;
env
=
"
prod
"
;
// #endif
const
api
=
{
...
...
pages/index/index.vue
View file @
ea87ad53
...
...
@@ -122,7 +122,7 @@ import API from '@/server/common'
import
{
isLogin
,
switchShowTabbar
}
from
'@/utils/index'
const
cacheIndexData
=
uni
.
getStorageSync
(
'dataIndex'
)
?
JSON
.
parse
(
uni
.
getStorageSync
(
'dataIndex'
))
:
null
;
const
indexGoods
=
uni
.
getStorageSync
(
'indexGoods'
)
?
JSON
.
parse
(
uni
.
getStorageSync
(
'indexGoods'
))
:
[];
let
timeOut
=
null
;
console
.
log
(
'首页数据'
,
cacheIndexData
)
console
.
log
(
'沃日'
,
indexGoods
)
...
...
@@ -174,6 +174,7 @@ export default {
},
// 监听页面滚动
onPageScroll
(
e
)
{
console
.
log
(
e
.
scrollTop
,
'日日'
)
if
(
e
.
scrollTop
>
this
.
Topdistance
)
{
this
.
isFixed
=
true
;
}
else
{
...
...
@@ -194,7 +195,7 @@ export default {
duration
:
0
})
this
.
Topdistance
=
0
;
setTimeout
(()
=>
{
timeOut
=
setTimeout
(()
=>
{
that
.
GetTop
()
// 获取元素距离顶部的距离
},
1500
)
...
...
@@ -207,6 +208,9 @@ export default {
// 首页流量埋点
this
.
buryingPoint
(
'app:index_page_view'
)
},
onHide
(){
if
(
timeOut
)
clearTimeout
(
timeOut
)
},
// 页面下拉刷新
async
onPullDownRefresh
()
{
...
...
server/common.js
View file @
ea87ad53
import
request
from
'@/utils/request.js'
export
default
{
/* 初始化 */
async
initTabBar
(
data
)
{
return
request
(
'/app/config/switchLoan'
,
'POST'
,
data
);
},
/* 初始化APP配置 */
async
initAPPSettings
(
data
)
{
return
request
(
'/app/version/getSetting'
,
'POST'
,
data
);
},
/* 初始化 */
async
initTabBar
(
data
)
{
return
request
(
'/app/config/switchLoan'
,
'POST'
,
data
);
},
/* 初始化APP配置 */
async
initAPPSettings
(
data
)
{
return
request
(
'/app/version/getSetting'
,
'POST'
,
data
);
},
/* 初始化贷超配置settings获取手机号 */
async
initH5Settings
(
data
)
{
return
request
(
'/app/v1/settings'
,
'GET'
,
data
);
return
request
(
'/app/v1/settings'
,
'GET'
,
data
);
},
/* 初始化首页 */
async
initIndex
(
data
)
{
return
request
(
'/app/index'
,
'POST'
,
data
);
return
request
(
'/app/index'
,
'POST'
,
data
);
},
/* 初始化首页商品 */
/* 初始化首页商品 */
async
initIndexGoods
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
/**********************支付后续的接口 */
// 地址列表
async
initAddressList
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 地址编辑初始化
async
initAddress
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 地址新增/编辑(更新)
async
addressSubmit
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 地址删除
async
addressDelete
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 创建订单快照
async
orderCreate
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 初始化订单快照
async
initOrder
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 订单提交
async
orderSubmit
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 初始化收银台
async
initCashier
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 收银台提交
async
cashierSubmit
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 初始化我的订单
async
initOrderList
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
// 订单取消
async
orderCancel
(
data
)
{
return
request
(
'/app/goods/getGoodsPage'
,
'POST'
,
data
);
},
}
subPackage/address/address.vue
View file @
ea87ad53
...
...
@@ -114,11 +114,11 @@
<image
src=
"/static/img-address-null.png"
></image>
<text>
暂无收货地址~
</text>
</view>
<
view
class=
"a-footer"
>
<
navigator
url=
"/subPackage/address/create"
hover-class=
"navigator-hover"
class=
"a-footer"
>
<view
class=
"a-btn"
>
<text>
+添加新收货人
</text>
</view>
</
view
>
</
navigator
>
</view>
</
template
>
...
...
subPackage/address/create.vue
View file @
ea87ad53
...
...
@@ -11,16 +11,15 @@
<view
class=
"a-form-item"
>
<text
class=
"a-label"
>
手机号码
</text>
<view
class=
"a-control"
>
<uni-easyinput
:inputBorder=
"inputBorder"
:placeholderStyle=
"placeholderStyle"
:styles=
"styles
"
placeholder=
"请输入收货人手机号"
></uni-easyinput>
<uni-easyinput
maxlength=
"11"
type=
"number"
:inputBorder=
"inputBorder
"
:placeholderStyle=
"placeholderStyle"
:styles=
"styles"
placeholder=
"请输入收货人手机号"
></uni-easyinput>
</view>
</view>
<view
class=
"a-form-item"
>
<text
class=
"a-label"
>
所在区域
</text>
<view
class=
"a-control"
>
<uni-data-picker
placeholder=
"请选择所在地区"
popup-title=
"请选择所在地区"
:localdata=
"dataTree"
v-model=
"classes"
@
change=
"onchange"
@
nodeclick=
"onnodeclick"
@
popupopened=
"onpopupopened"
@
popupclosed=
"onpopupclosed"
>
<uni-data-picker
placeholder=
"请选择所在地区"
popup-title=
"请选择所在地区"
:localdata=
"localData"
v-model=
"classes"
@
change=
"onchange"
@
nodeclick=
"onnodeclick"
>
</uni-data-picker>
</view>
</view>
...
...
@@ -40,6 +39,7 @@
</
template
>
<
script
>
import
cityRows
from
"../../common/city-china/data.json"
;
export
default
{
name
:
"AddressCreate"
,
data
()
{
...
...
@@ -57,37 +57,12 @@ export default {
},
classes
:
'1-2'
,
dataTree
:
[{
text
:
"一年级"
,
value
:
"1-0"
,
children
:
[{
text
:
"1.1班"
,
value
:
"1-1"
},
{
text
:
"1.2班"
,
value
:
"1-2"
}]
},
{
text
:
"二年级"
,
value
:
"2-0"
,
children
:
[{
text
:
"2.1班"
,
value
:
"2-1"
},
{
text
:
"2.2班"
,
value
:
"2-2"
}]
},
{
text
:
"三年级"
,
value
:
"3-0"
,
disable
:
true
}]
localData
:
[]
}
},
onLoad
(){
this
.
localData
=
this
.
get_city_tree
()
},
methods
:
{
onnodeclick
(
e
)
{
console
.
log
(
e
);
...
...
@@ -100,6 +75,115 @@ export default {
},
onchange
(
e
)
{
console
.
log
(
'onchange:'
,
e
);
},
// 节点变化后 (并非已经选择完毕)
onnodeclick
(
node
)
{
// console.log(JSON.stringify(node))
},
// 整体选择完成以后
onchange
(
e
)
{
const
value
=
e
.
detail
.
value
console
.
log
(
JSON
.
stringify
(
value
))
},
// 省市区数据树生成
get_city_tree
()
{
let
res
=
[]
if
(
cityRows
.
length
)
{
// 递归生成
res
=
this
.
handleTree
(
cityRows
)
}
return
res
},
/**
* 递归生成树结构数据 - 省市区
*
* @param {Object} data
* @param {String} parent_code 上级ID | null代表需要顶部菜单
* @author Rudon https://rudon.blog.csdn.net/
*
* 源数据:
* {
* "code": "110100",
* "name": "北京市",
* "pinyin": "beijingshi",
* "zip_code": "100000",
* "parent_code": "110000",
* "type": 1,
* "first_letter": "B"
* }
*
* 目标:
* {
* text: "XX市",
* value: "810000",
* children: []
* }
*
*/
handleTree
(
data
,
parent_code
=
null
)
{
let
res
=
[]
let
keys
=
{
id
:
'code'
,
pid
:
'parent_code'
,
children
:
'children'
,
text
:
'name'
,
value
:
'code'
}
let
oneItemDEMO
=
{
text
:
''
,
value
:
''
,
children
:
[]
}
let
oneItem
=
{}
// 循环
for
(
let
index
in
data
)
{
// 判断
if
(
parent_code
===
null
)
{
// 顶级菜单 - 省
if
(
!
data
[
index
].
hasOwnProperty
(
keys
.
pid
)
||
data
[
index
][
keys
.
pid
]
==
parent_code
)
{
// 不存在parent_code,或者已匹配
oneItem
=
JSON
.
parse
(
JSON
.
stringify
(
oneItemDEMO
))
oneItem
.
text
=
data
[
index
][
keys
.
text
]
oneItem
.
value
=
data
[
index
][
keys
.
value
]
// 递归下去
oneItem
.
children
=
this
.
handleTree
(
data
,
data
[
index
][
keys
.
id
])
res
.
push
(
oneItem
)
}
else
{
// 匹配不到,跳过
}
}
else
{
// 非顶级菜单 - 市、区、街道
if
(
data
[
index
].
hasOwnProperty
(
keys
.
pid
)
&&
data
[
index
][
keys
.
pid
]
==
parent_code
)
{
// 已匹配
oneItem
=
JSON
.
parse
(
JSON
.
stringify
(
oneItemDEMO
))
oneItem
.
text
=
data
[
index
][
keys
.
text
]
oneItem
.
value
=
data
[
index
][
keys
.
value
]
// 递归下去
oneItem
.
children
=
this
.
handleTree
(
data
,
data
[
index
][
keys
.
id
])
res
.
push
(
oneItem
)
}
else
{
// 匹配不到,跳过
}
}
}
return
res
}
}
}
...
...
subPackage/order/order.vue
View file @
ea87ad53
<
template
>
<view
class=
"page-order"
>
<!-- 没有选择地址 -->
<
view
class=
"o-address"
>
<
navigator
url=
"/subPackage/address/address"
hover-class=
"navigator-hover"
class=
"o-address"
>
<view
class=
"o-address-placeholder"
>
<text>
请选择地址
</text>
</view>
<image
class=
"o-address-arrow"
src=
"/static/o-address-arrow.png"
></image>
</
view
>
</
navigator
>
<!-- 选择了地址 -->
<
view
class=
"o-address"
>
<
navigator
url=
"/subPackage/address/address"
hover-class=
"navigator-hover"
class=
"o-address"
>
<view
class=
"o-address-box"
>
<text
class=
"o-address-area"
>
请选择地址
</text>
<text
class=
"o-address-detail"
>
请选择地址
</text>
<text
class=
"o-address-name"
>
请选择地址
</text>
</view>
<image
class=
"o-address-arrow"
src=
"/static/o-address-arrow.png"
></image>
</
view
>
</
navigator
>
<view
class=
"o-snapshot"
>
<view
class=
"s-image"
>
<image
mode=
"widthFix"
src=
"/static/o-address-arrow.png"
/>
...
...
@@ -51,7 +51,7 @@
<text>
¥
</text>
<text>
8999.00
</text>
</view>
<view
class=
"o-btn"
>
<view
@
click=
"handleSubmit"
class=
"o-btn"
>
<text>
提交订单
</text>
</view>
</view>
...
...
@@ -59,14 +59,37 @@
</
template
>
<
script
>
import
API
from
'../../server/common.js'
export
default
{
data
()
{
return
{
form
:
null
,
address
:
null
}
},
onLoad
(){},
onShow
(){
const
address
=
uni
.
getStorageSync
(
'ChooseAddress'
);
if
(
address
){
this
.
address
=
JSON
.
parse
(
address
);
}
},
methods
:
{
// 初始化订单
async
init
(){
try
{
const
res
=
await
API
.
initOrder
();
if
(
res
.
success
){
}
}
catch
(
err
){
console
.
log
(
err
)
}
},
// 订单提交
handleSubmit
(){
}
}
}
</
script
>
...
...
subPackage/productDetails/productDetails.vue
View file @
ea87ad53
...
...
@@ -143,8 +143,8 @@ export default {
return
false
}
// 这里下订单之前应该先查询一下商品的状态,但我们这个只是假的,不知道要不要判断
this
.
Go
(
'uni:/subPackage/order/order'
)
//
this.Go('uni:/subPackage/detailResult/detailResult', 'redirect')
//
this.Go('uni:/subPackage/order/order')
this
.
Go
(
'uni:/subPackage/detailResult/detailResult'
,
'redirect'
)
}
},
Gopurse
()
{
...
...
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