Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
750abbcf
U
uni-app
项目概览
DCloud
/
uni-app
4 个月 前同步成功
通知
730
Star
38706
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
7
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
7
Issue
7
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
750abbcf
编写于
8月 28, 2019
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 解决纯 nvue 环境 uni.scanCode、uni.chooseLocation 回调不执行的 Bug
上级
e03f4c9e
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
62 addition
and
39 deletion
+62
-39
src/platforms/app-plus/service/api/device/scan-code.js
src/platforms/app-plus/service/api/device/scan-code.js
+14
-17
src/platforms/app-plus/service/api/location/choose-location.js
...latforms/app-plus/service/api/location/choose-location.js
+36
-21
src/platforms/app-plus/service/framework/app.js
src/platforms/app-plus/service/framework/app.js
+12
-1
未找到文件。
src/platforms/app-plus/service/api/device/scan-code.js
浏览文件 @
750abbcf
...
...
@@ -12,7 +12,8 @@ import {
}
from
'
../../constants
'
import
{
registerPlusMessage
registerPlusMessage
,
consumePlusMessage
}
from
'
../../framework/plus-message
'
export
const
SCAN_ID
=
'
__UNIAPP_SCAN
'
...
...
@@ -97,12 +98,12 @@ export function scanCode ({
barcode
.
scan
(
file
,
(
type
,
code
)
=>
{
if
(
isDark
)
{
plus
.
navigator
.
setStatusBarStyle
(
'
isDark
'
)
}
result
=
{
type
,
code
}
webview
.
close
(
'
auto
'
)
result
=
{
type
,
code
}
},
()
=>
{
plus
.
nativeUI
.
toast
(
'
识别失败
'
)
},
filters
)
...
...
@@ -143,7 +144,7 @@ export function scanCode ({
})
})
webview
.
addEventListener
(
'
close
'
,
()
=>
{
if
(
result
&&
'
code
'
in
result
)
{
if
(
result
)
{
invoke
(
callbackId
,
{
result
:
result
.
code
,
scanType
:
SCAN_MAPS
[
result
.
type
]
||
''
,
...
...
@@ -151,11 +152,12 @@ export function scanCode ({
path
:
''
,
errMsg
:
'
scanCode:ok
'
})
}
else
{
invoke
(
callbackId
,
{
errMsg
:
'
scanCode:fail cancel
'
})
}
else
{
invoke
(
callbackId
,
{
errMsg
:
'
scanCode:fail cancel
'
})
}
consumePlusMessage
(
MESSAGE_TYPE
)
})
if
(
isDark
)
{
// 状态栏前景色
plus
.
navigator
.
setStatusBarStyle
(
'
light
'
)
...
...
@@ -170,15 +172,10 @@ export function scanCode ({
}
})
}
// fixed by hxy 注册扫码事件
registerPlusMessage
(
MESSAGE_TYPE
,
function
(
res
)
{
if
(
res
&&
!
res
.
errMsg
)
{
if
(
res
&&
'
code
'
in
res
)
{
result
=
res
}
else
{
const
errMsg
=
res
&&
res
.
errMsg
?
'
'
+
res
.
errMsg
:
''
result
=
{
errMsg
:
'
scanCode:fail
'
+
errMsg
}
}
},
false
)
}
src/platforms/app-plus/service/api/location/choose-location.js
浏览文件 @
750abbcf
...
...
@@ -11,10 +11,13 @@ import {
}
from
'
../../constants
'
import
{
registerPlusMessage
registerPlusMessage
,
consumePlusMessage
}
from
'
../../framework/plus-message
'
const
CHOOSE_LOCATION_PATH
=
'
_www/__uniappchooselocation.html
'
const
CHOOSE_LOCATION_PATH
=
'
_www/__uniappchooselocation.html
'
const
MESSAGE_TYPE
=
'
chooseLocation
'
export
function
chooseLocation
(
params
,
callbackId
)
{
const
statusBarStyle
=
plus
.
navigator
.
getStatusBarStyle
()
...
...
@@ -56,27 +59,39 @@ export function chooseLocation (params, callbackId) {
plus
.
navigator
.
setStatusBarStyle
(
'
light
'
)
}
})
}
let
index
=
0
let
onShow
=
function
()
{
index
++
if
(
index
===
2
)
{
webview
.
evalJS
(
`__chooseLocation__(
${
JSON
.
stringify
(
params
)}
)`
)
}
}
webview
.
addEventListener
(
'
loaded
'
,
onShow
)
webview
.
show
(
'
slide-in-bottom
'
,
ANI_DURATION
,
onShow
)
let
result
webview
.
addEventListener
(
'
close
'
,
()
=>
{
if
(
result
)
{
invoke
(
callbackId
,
{
name
:
result
.
poiname
,
address
:
result
.
poiaddress
,
latitude
:
result
.
latlng
.
lat
,
longitude
:
result
.
latlng
.
lng
,
errMsg
:
'
chooseLocation:ok
'
})
}
else
{
consumePlusMessage
(
MESSAGE_TYPE
)
invoke
(
callbackId
,
{
errMsg
:
'
chooseLocation:fail cancel
'
})
}
})
webview
.
show
(
'
slide-in-bottom
'
,
ANI_DURATION
,
()
=>
{
webview
.
evalJS
(
`__chooseLocation__(
${
JSON
.
stringify
(
params
)}
)`
)
})
// fixed by hxy
registerPlusMessage
(
'
chooseLocation
'
,
function
(
res
)
{
if
(
res
&&
!
res
.
errMsg
)
{
invoke
(
callbackId
,
{
name
:
res
.
poiname
,
address
:
res
.
poiaddress
,
latitude
:
res
.
latlng
.
lat
,
longitude
:
res
.
latlng
.
lng
,
errMsg
:
'
chooseLocation:ok
'
})
}
else
{
const
errMsg
=
res
&&
res
.
errMsg
?
'
'
+
res
.
errMsg
:
''
invoke
(
callbackId
,
{
errMsg
:
'
chooseLocation:fail
'
+
errMsg
})
registerPlusMessage
(
MESSAGE_TYPE
,
function
(
res
)
{
if
(
res
&&
'
latlng
'
in
res
)
{
result
=
res
}
},
false
)
}
src/platforms/app-plus/service/framework/app.js
浏览文件 @
750abbcf
...
...
@@ -9,7 +9,8 @@ import {
}
from
'
./page
'
import
{
registerPlusMessage
registerPlusMessage
,
consumePlusMessage
}
from
'
./plus-message
'
import
{
...
...
@@ -68,6 +69,16 @@ function initGlobalListeners () {
publish
(
'
onKeyboardHeightChange
'
,
{
height
:
event
.
height
})
})
plus
.
globalEvent
.
addEventListener
(
'
plusMessage
'
,
function
(
e
)
{
if
(
process
.
env
.
NODE_ENV
!==
'
production
'
)
{
console
.
log
(
'
UNIAPP[plusMessage]:[
'
+
Date
.
now
()
+
'
]
'
+
JSON
.
stringify
(
e
.
data
))
}
if
(
e
.
data
&&
e
.
data
.
type
)
{
const
type
=
e
.
data
.
type
consumePlusMessage
(
type
,
e
.
data
.
args
||
{})
}
})
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录