Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
8a240267
U
uni-app
项目概览
DCloud
/
uni-app
3 个月 前同步成功
通知
725
Star
38705
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,发现更多精彩内容 >>
提交
8a240267
编写于
8月 14, 2020
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 修复小程序 v-if 中复杂表达式的作用域
上级
78b7da84
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
10 deletion
+21
-10
packages/uni-template-compiler/lib/script/traverse/member-expr.js
.../uni-template-compiler/lib/script/traverse/member-expr.js
+21
-10
未找到文件。
packages/uni-template-compiler/lib/script/traverse/member-expr.js
浏览文件 @
8a240267
...
...
@@ -11,7 +11,7 @@ function isMatch (name, forItem, forIndex) {
return
name
===
forItem
||
name
===
forIndex
}
function
findScoped
(
path
,
state
)
{
function
findScoped
(
path
,
test
,
state
)
{
if
(
!
path
)
{
return
state
}
...
...
@@ -21,17 +21,28 @@ function findScoped (path, state) {
forIndex
}
=
scoped
let
match
=
false
path
.
traverse
({
noScope
:
true
,
Identifier
(
path
)
{
if
(
!
match
&&
path
.
key
!==
'
key
'
&&
(
path
.
key
!==
'
property
'
||
path
.
parent
.
computed
))
{
match
=
isMatch
(
path
.
node
.
name
,
forItem
,
forIndex
)
if
(
match
)
{
path
.
stop
()
}
function
Identifier
(
path
)
{
if
(
!
match
&&
path
.
key
!==
'
key
'
&&
(
path
.
key
!==
'
property
'
||
path
.
parent
.
computed
))
{
match
=
isMatch
(
path
.
node
.
name
,
forItem
,
forIndex
)
if
(
match
)
{
path
.
stop
()
}
}
}
path
.
traverse
({
noScope
:
true
,
Identifier
})
if
(
!
match
)
{
if
(
t
.
isIdentifier
(
test
,
{
name
:
IDENTIFIER_METHOD
})
||
t
.
isIdentifier
(
test
,
{
name
:
IDENTIFIER_FILTER
}))
{
match
=
scoped
.
declarationArray
.
find
(({
declarations
})
=>
declarations
.
find
(({
id
})
=>
id
===
test
))
}
else
if
(
!
match
)
{
traverse
(
test
,
{
noScope
:
true
,
Identifier
})
}
}
return
match
})
if
(
!
scoped
&&
state
.
scoped
.
length
>
1
)
{
...
...
@@ -84,8 +95,8 @@ function findTest (path, state) {
}
module
.
exports
=
function
getMemberExpr
(
path
,
name
,
init
,
state
,
variableDeclaration
=
true
)
{
const
scoped
=
findScoped
(
path
,
state
)
const
test
=
findTest
(
path
,
state
)
const
scoped
=
findScoped
(
path
,
test
,
state
)
if
(
!
variableDeclaration
)
{
scoped
.
declarationArray
.
push
(
t
.
expressionStatement
(
init
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录