Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
genary
uni-app
提交
e9a2b355
U
uni-app
项目概览
genary
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
e9a2b355
编写于
3月 19, 2021
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mp): 优化含有逻辑运算的复杂表达式编译 question/118651
上级
90b254e5
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
41 addition
and
37 deletion
+41
-37
packages/uni-template-compiler/__tests__/compiler-extra.spec.js
...es/uni-template-compiler/__tests__/compiler-extra.spec.js
+2
-2
packages/uni-template-compiler/lib/script/traverse/visitor.js
...ages/uni-template-compiler/lib/script/traverse/visitor.js
+39
-35
未找到文件。
packages/uni-template-compiler/__tests__/compiler-extra.spec.js
浏览文件 @
e9a2b355
...
...
@@ -739,8 +739,8 @@ describe('mp:compiler-extra', () => {
)
assertCodegen
(
'
<view v-if="test1(key)&&test2(key)">{{getValue(key)}}</view>
'
,
'
<block wx:if="{{$root.m0
&&$root.m1}}"><view>{{$root.m2
}}</view></block>
'
,
'
with(this){var m0=test1(key)
;var m1=test2(key);var m2=m0&&m1?getValue(key):null;$mp.data=Object.assign({},{$root:{m0:m0,m1:m1,m2:m2
}})}
'
'
<block wx:if="{{$root.m0
}}"><view>{{$root.m1
}}</view></block>
'
,
'
with(this){var m0=test1(key)
&&test2(key);var m1=m0?getValue(key):null;$mp.data=Object.assign({},{$root:{m0:m0,m1:m1
}})}
'
)
assertCodegen
(
'
<view v-for="(item,index) in list" :key="index"><view v-if="item">{{getValue(item)}}</view></view>
'
,
...
...
packages/uni-template-compiler/lib/script/traverse/visitor.js
浏览文件 @
e9a2b355
...
...
@@ -15,7 +15,7 @@ const {
getTagName
}
=
require
(
'
../../h5
'
)
const
{
const
{
hasOwn
,
hyphenate
,
traverseFilter
,
...
...
@@ -149,41 +149,41 @@ module.exports = {
const
methodName
=
callee
.
name
switch
(
methodName
)
{
case
METHOD_CREATE_ELEMENT
:
{
const
tagNode
=
path
.
node
.
arguments
[
0
]
if
(
t
.
isStringLiteral
(
tagNode
))
{
// 需要把标签增加到 class 样式中
const
tagName
=
getTagName
(
tagNode
.
value
)
if
(
tagName
!==
tagNode
.
value
)
{
addStaticClass
(
path
,
'
_
'
+
tagNode
.
value
)
}
tagNode
.
value
=
getComponentName
(
hyphenate
(
tagName
))
// 组件增加 vueId
if
(
this
.
options
.
platform
.
isComponent
(
tagNode
.
value
))
{
addVueId
(
path
,
this
)
}
// 查找全局组件
checkUsingGlobalComponents
(
tagNode
.
value
,
this
.
options
.
globalUsingComponents
,
this
)
}
if
(
this
.
options
.
scopeId
)
{
addStaticClass
(
path
,
this
.
options
.
scopeId
)
}
const
dataPath
=
path
.
get
(
'
arguments.1
'
)
dataPath
&&
dataPath
.
isObjectExpression
()
&&
traverseData
(
dataPath
,
this
,
tagNode
.
value
)
{
const
tagNode
=
path
.
node
.
arguments
[
0
]
if
(
t
.
isStringLiteral
(
tagNode
))
{
// 需要把标签增加到 class 样式中
const
tagName
=
getTagName
(
tagNode
.
value
)
if
(
tagName
!==
tagNode
.
value
)
{
addStaticClass
(
path
,
'
_
'
+
tagNode
.
value
)
}
tagNode
.
value
=
getComponentName
(
hyphenate
(
tagName
))
// 组件增加 vueId
if
(
this
.
options
.
platform
.
isComponent
(
tagNode
.
value
))
{
addVueId
(
path
,
this
)
}
// 查找全局组件
checkUsingGlobalComponents
(
tagNode
.
value
,
this
.
options
.
globalUsingComponents
,
this
)
}
if
(
this
.
options
.
scopeId
)
{
addStaticClass
(
path
,
this
.
options
.
scopeId
)
}
const
dataPath
=
path
.
get
(
'
arguments.1
'
)
dataPath
&&
dataPath
.
isObjectExpression
()
&&
traverseData
(
dataPath
,
this
,
tagNode
.
value
)
}
break
case
METHOD_TO_STRING
:
{
const
stringNodes
=
path
.
node
.
arguments
[
0
]
stringNodes
.
$toString
=
true
path
.
replaceWith
(
stringNodes
)
{
const
stringNodes
=
path
.
node
.
arguments
[
0
]
stringNodes
.
$toString
=
true
path
.
replaceWith
(
stringNodes
)
}
break
case
METHOD_RENDER_LIST
:
...
...
@@ -202,7 +202,11 @@ module.exports = {
// event
return
path
.
skip
()
}
path
=
path
.
findParent
((
path
)
=>
path
.
isLogicalExpression
())
||
path
path
.
skip
()
if
(
path
.
findParent
((
path
)
=>
path
.
shouldSkip
))
{
return
}
path
.
replaceWith
(
getMemberExpr
(
path
,
...
...
@@ -265,4 +269,4 @@ module.exports = {
path
.
replaceWith
(
root
)
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录