Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
9c0091f8
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,发现更多精彩内容 >>
提交
9c0091f8
编写于
6月 17, 2019
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(h5): add lifecycle strategies
上级
bac62d59
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
72 addition
and
13 deletion
+72
-13
src/core/service/plugins/index.js
src/core/service/plugins/index.js
+7
-1
src/core/service/plugins/lifecycle.js
src/core/service/plugins/lifecycle.js
+57
-0
src/core/service/plugins/util.js
src/core/service/plugins/util.js
+8
-12
未找到文件。
src/core/service/plugins/index.js
浏览文件 @
9c0091f8
...
@@ -16,6 +16,10 @@ import {
...
@@ -16,6 +16,10 @@ import {
createPageMixin
createPageMixin
}
from
'
./page
'
}
from
'
./page
'
import
{
lifecycleMixin
}
from
'
./lifecycle
'
import
{
import
{
getTabBarScrollPosition
getTabBarScrollPosition
}
from
'
./app/router-guard
'
}
from
'
./app/router-guard
'
...
@@ -55,7 +59,9 @@ function getLocation (base = '/') {
...
@@ -55,7 +59,9 @@ function getLocation (base = '/') {
export
default
{
export
default
{
install
(
Vue
,
{
install
(
Vue
,
{
routes
routes
}
=
{})
{
}
=
{})
{
lifecycleMixin
(
Vue
)
const
minId
=
getMinId
(
routes
)
const
minId
=
getMinId
(
routes
)
const
router
=
new
VueRouter
({
const
router
=
new
VueRouter
({
id
:
minId
,
id
:
minId
,
...
...
src/core/service/plugins/lifecycle.js
0 → 100644
浏览文件 @
9c0091f8
/* @flow */
const
LIFECYCLE_HOOKS
=
[
// App
'
onLaunch
'
,
'
onShow
'
,
'
onHide
'
,
'
onUniNViewMessage
'
,
'
onError
'
,
// Page
'
onLoad
'
,
// 'onShow',
'
onReady
'
,
// 'onHide',
'
onUnload
'
,
'
onPullDownRefresh
'
,
'
onReachBottom
'
,
'
onTabItemTap
'
,
'
onShareAppMessage
'
,
'
onResize
'
,
'
onPageScroll
'
,
'
onNavigationBarButtonTap
'
,
'
onBackPress
'
,
'
onNavigationBarSearchInputChanged
'
,
'
onNavigationBarSearchInputConfirmed
'
,
'
onNavigationBarSearchInputClicked
'
,
// Component
// 'onReady', // 兼容旧版本,应该移除该事件
'
onPageShow
'
,
'
onPageHide
'
,
'
onPageResize
'
]
export
function
lifecycleMixin
(
Vue
)
{
// fixed vue-class-component
const
oldExtend
=
Vue
.
extend
Vue
.
extend
=
function
(
extendOptions
)
{
extendOptions
=
extendOptions
||
{}
const
methods
=
extendOptions
.
methods
if
(
methods
)
{
Object
.
keys
(
methods
).
forEach
(
methodName
=>
{
if
(
LIFECYCLE_HOOKS
.
indexOf
(
methodName
)
!==
-
1
)
{
extendOptions
[
methodName
]
=
methods
[
methodName
]
delete
methods
[
methodName
]
}
})
}
return
oldExtend
.
call
(
this
,
extendOptions
)
}
const
strategies
=
Vue
.
config
.
optionMergeStrategies
const
mergeHook
=
strategies
.
created
LIFECYCLE_HOOKS
.
forEach
(
hook
=>
{
strategies
[
hook
]
=
mergeHook
})
}
src/core/service/plugins/util.js
浏览文件 @
9c0091f8
import
{
isFn
}
from
'
uni-shared
'
function
callHook
(
vm
,
hook
,
params
)
{
function
callHook
(
vm
,
hook
,
params
)
{
return
isFn
(
vm
.
$options
[
hook
])
&&
vm
.
$options
[
hook
].
apply
(
vm
,
params
)
return
vm
.
__call_hook
(
hook
,
params
)
}
}
export
function
callAppHook
(
vm
,
hook
,
...
params
)
{
export
function
callAppHook
(
vm
,
hook
,
...
params
)
{
...
@@ -20,12 +16,12 @@ export function callPageHook (vm, hook, ...params) {
...
@@ -20,12 +16,12 @@ export function callPageHook (vm, hook, ...params) {
vm
.
$mp
.
query
=
params
[
0
]
vm
.
$mp
.
query
=
params
[
0
]
UniServiceJSBridge
.
publishHandler
(
'
onPageLoad
'
,
vm
,
vm
.
$page
.
id
)
UniServiceJSBridge
.
publishHandler
(
'
onPageLoad
'
,
vm
,
vm
.
$page
.
id
)
}
}
if
(
hook
===
'
onShow
'
)
{
if
(
hook
===
'
onShow
'
)
{
if
(
if
(
vm
.
$route
.
meta
.
isTabBar
&&
vm
.
$route
.
meta
.
isTabBar
&&
vm
.
$route
.
params
.
detail
vm
.
$route
.
params
.
detail
)
{
)
{
UniServiceJSBridge
.
emit
(
'
onTabItemTap
'
,
vm
.
$route
.
params
.
detail
)
UniServiceJSBridge
.
emit
(
'
onTabItemTap
'
,
vm
.
$route
.
params
.
detail
)
}
}
UniServiceJSBridge
.
publishHandler
(
'
onPageShow
'
,
vm
,
vm
.
$page
.
id
)
UniServiceJSBridge
.
publishHandler
(
'
onPageShow
'
,
vm
,
vm
.
$page
.
id
)
}
}
...
@@ -34,4 +30,4 @@ export function callPageHook (vm, hook, ...params) {
...
@@ -34,4 +30,4 @@ export function callPageHook (vm, hook, ...params) {
console
.
debug
(
`
${
vm
.
$page
.
route
}
[
${
vm
.
$page
.
id
}
]:
${
hook
}
have been invoked`
)
console
.
debug
(
`
${
vm
.
$page
.
route
}
[
${
vm
.
$page
.
id
}
]:
${
hook
}
have been invoked`
)
}
}
return
callHook
(
vm
,
hook
,
params
)
return
callHook
(
vm
,
hook
,
params
)
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录