Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
一把秋刀鱼
uni-app
提交
69f43048
U
uni-app
项目概览
一把秋刀鱼
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
4
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
69f43048
编写于
3月 28, 2019
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(runtime): onShareAppMessage,props sync
上级
6d451bf3
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
57 addition
and
21 deletion
+57
-21
packages/uni-mp-weixin/dist/index.js
packages/uni-mp-weixin/dist/index.js
+28
-10
packages/uni-mp-weixin/package.json
packages/uni-mp-weixin/package.json
+1
-1
src/core/runtime/wrapper/util.js
src/core/runtime/wrapper/util.js
+28
-10
未找到文件。
packages/uni-mp-weixin/dist/index.js
浏览文件 @
69f43048
...
...
@@ -282,7 +282,7 @@ function initMocks (vm) {
function
initHooks
(
mpOptions
,
hooks
)
{
hooks
.
forEach
(
hook
=>
{
mpOptions
[
hook
]
=
function
(
args
)
{
this
.
$vm
.
__call_hook
(
hook
,
args
);
return
this
.
$vm
.
__call_hook
(
hook
,
args
)
};
});
}
...
...
@@ -404,6 +404,14 @@ function processEventArgs (event, args = [], isCustom) {
const
ONCE
=
'
~
'
;
const
CUSTOM
=
'
^
'
;
function
getTarget
(
obj
,
path
)
{
const
parts
=
path
.
split
(
'
.
'
);
if
(
parts
.
length
===
1
)
{
return
obj
[
parts
[
0
]]
}
return
getTarget
(
obj
[
parts
[
0
]],
parts
.
slice
(
1
).
join
(
'
.
'
))
}
function
handleEvent
(
event
)
{
event
=
wrapper$1
(
event
);
...
...
@@ -426,17 +434,27 @@ function handleEvent (event) {
if
(
eventsArray
&&
eventType
===
type
)
{
eventsArray
.
forEach
(
eventArray
=>
{
const
handler
=
this
.
$vm
[
eventArray
[
0
]];
if
(
!
isFn
(
handler
))
{
throw
new
Error
(
` _vm.
${
eventArray
[
0
]}
is not a function`
)
}
if
(
isOnce
)
{
if
(
handler
.
once
)
{
return
const
methodName
=
eventArray
[
0
];
if
(
methodName
===
'
$set
'
)
{
// prop.sync
const
args
=
eventArray
[
1
];
if
(
args
.
length
===
2
)
{
// :title.sync="title"
this
.
$vm
[
args
[
0
]]
=
event
.
detail
[
0
];
}
else
if
(
args
.
length
===
3
)
{
this
.
$vm
.
$set
(
getTarget
(
this
.
$vm
,
args
[
0
]),
args
[
1
],
event
.
detail
[
0
]);
}
}
else
{
const
handler
=
this
.
$vm
[
methodName
];
if
(
!
isFn
(
handler
))
{
throw
new
Error
(
` _vm.
${
methodName
}
is not a function`
)
}
if
(
isOnce
)
{
if
(
handler
.
once
)
{
return
}
handler
.
once
=
true
;
}
handler
.
once
=
true
;
handler
.
apply
(
this
.
$vm
,
processEventArgs
(
event
,
eventArray
[
1
],
isCustom
))
;
}
handler
.
apply
(
this
.
$vm
,
processEventArgs
(
event
,
eventArray
[
1
],
isCustom
));
});
}
});
...
...
packages/uni-mp-weixin/package.json
浏览文件 @
69f43048
{
"name"
:
"@dcloudio/uni-mp-weixin"
,
"version"
:
"0.0.91
6
"
,
"version"
:
"0.0.91
8
"
,
"description"
:
"uni-app mp-weixin"
,
"main"
:
"dist/index.js"
,
"scripts"
:
{
...
...
src/core/runtime/wrapper/util.js
浏览文件 @
69f43048
...
...
@@ -19,7 +19,7 @@ export function initMocks (vm) {
export
function
initHooks
(
mpOptions
,
hooks
)
{
hooks
.
forEach
(
hook
=>
{
mpOptions
[
hook
]
=
function
(
args
)
{
this
.
$vm
.
__call_hook
(
hook
,
args
)
return
this
.
$vm
.
__call_hook
(
hook
,
args
)
}
})
}
...
...
@@ -147,6 +147,14 @@ function processEventArgs (event, args = [], isCustom) {
const
ONCE
=
'
~
'
const
CUSTOM
=
'
^
'
function
getTarget
(
obj
,
path
)
{
const
parts
=
path
.
split
(
'
.
'
)
if
(
parts
.
length
===
1
)
{
return
obj
[
parts
[
0
]]
}
return
getTarget
(
obj
[
parts
[
0
]],
parts
.
slice
(
1
).
join
(
'
.
'
))
}
export
function
handleEvent
(
event
)
{
event
=
wrapper
(
event
)
...
...
@@ -169,17 +177,27 @@ export function handleEvent (event) {
if
(
eventsArray
&&
eventType
===
type
)
{
eventsArray
.
forEach
(
eventArray
=>
{
const
handler
=
this
.
$vm
[
eventArray
[
0
]]
if
(
!
isFn
(
handler
))
{
throw
new
Error
(
` _vm.
${
eventArray
[
0
]}
is not a function`
)
}
if
(
isOnce
)
{
if
(
handler
.
once
)
{
return
const
methodName
=
eventArray
[
0
]
if
(
methodName
===
'
$set
'
)
{
// prop.sync
const
args
=
eventArray
[
1
]
if
(
args
.
length
===
2
)
{
// :title.sync="title"
this
.
$vm
[
args
[
0
]]
=
event
.
detail
[
0
]
}
else
if
(
args
.
length
===
3
)
{
this
.
$vm
.
$set
(
getTarget
(
this
.
$vm
,
args
[
0
]),
args
[
1
],
event
.
detail
[
0
])
}
}
else
{
const
handler
=
this
.
$vm
[
methodName
]
if
(
!
isFn
(
handler
))
{
throw
new
Error
(
` _vm.
${
methodName
}
is not a function`
)
}
if
(
isOnce
)
{
if
(
handler
.
once
)
{
return
}
handler
.
once
=
true
}
handler
.
once
=
true
handler
.
apply
(
this
.
$vm
,
processEventArgs
(
event
,
eventArray
[
1
],
isCustom
))
}
handler
.
apply
(
this
.
$vm
,
processEventArgs
(
event
,
eventArray
[
1
],
isCustom
))
})
}
})
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录