Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
5485f47f
U
uni-app
项目概览
DCloud
/
uni-app
14 天 前同步成功
通知
751
Star
38709
Fork
3642
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
8
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
8
Issue
8
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
5485f47f
编写于
10月 09, 2021
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
wip(mp): vFor
上级
af2df6ba
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
163 addition
and
30 deletion
+163
-30
packages/uni-mp-compiler/__tests__/test.spec.ts
packages/uni-mp-compiler/__tests__/test.spec.ts
+3
-3
packages/uni-mp-compiler/__tests__/vFor.spec.ts
packages/uni-mp-compiler/__tests__/vFor.spec.ts
+138
-20
packages/uni-mp-compiler/src/transforms/transformIdentifier.ts
...ges/uni-mp-compiler/src/transforms/transformIdentifier.ts
+17
-3
packages/uni-mp-compiler/src/transforms/vFor.ts
packages/uni-mp-compiler/src/transforms/vFor.ts
+5
-4
未找到文件。
packages/uni-mp-compiler/__tests__/test.spec.ts
浏览文件 @
5485f47f
...
...
@@ -22,10 +22,10 @@ function assert(template: string, templateCode: string, renderCode: string) {
}
describe
(
'
compiler
'
,
()
=>
{
test
(
'
template v-for key no prefixing on attribute key
'
,
()
=>
{
test
(
`keyed v-for`
,
()
=>
{
assert
(
`<
template v-for="item in items" key="key">test</template
>`
,
`<
block wx:for="{{a}}" wx:for-item="item" key="key">test</block
>`
,
`<
view v-for="(item) in items" :key="item" /
>`
,
`<
view wx:for="{{a}}" wx:for-item="item" wx:key="*this"/
>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
...
...
packages/uni-mp-compiler/__tests__/vFor.spec.ts
浏览文件 @
5485f47f
...
...
@@ -196,6 +196,124 @@ return {
}`
)
})
test
(
`template v-for`
,
()
=>
{
assert
(
`<template v-for="item in items">hello<view/></template>`
,
`<block wx:for="{{a}}" wx:for-item="item">hello<view/></block>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {};
})
}
}`
)
})
test
(
`template v-for w/ <slot/>`
,
()
=>
{
assert
(
`<template v-for="item in items"><slot/></template>`
,
`<block wx:for="{{a}}" wx:for-item="item"><slot/></block>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {};
})
}
}`
)
})
// #1907 TODO 待优化
test
(
`template v-for key injection with single child`
,
()
=>
{
assert
(
`<template v-for="item in items" :key="item.id"><view :id="item.id" /></template>`
,
`<block wx:for="{{a}}" wx:for-item="item" wx:key="b"><view id="{{item.a}}"/></block>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {
a: item.id,
b: item.id
};
})
}
}`
)
})
test
(
`v-for on <slot/>`
,
()
=>
{
assert
(
`<slot v-for="item in items"></slot>`
,
`<slot wx:for="{{a}}" wx:for-item="item"></slot>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {};
})
}
}`
)
})
test
(
`keyed v-for`
,
()
=>
{
assert
(
`<view v-for="(item) in items" :key="item" />`
,
`<view wx:for="{{a}}" wx:for-item="item" wx:key="*this"/>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {};
})
}
}`
)
})
test
(
`keyed template v-for`
,
()
=>
{
assert
(
`<template v-for="item in items" :key="item">hello<view/></template>`
,
`<block wx:for="{{a}}" wx:for-item="item" wx:key="*this">hello<view/></block>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
return {};
})
}
}`
)
})
test
(
`v-if + v-for`
,
()
=>
{
assert
(
`<view v-if="ok" v-for="i in list"/>`
,
`<view wx:if="{{b}}" wx:for="{{a}}" wx:for-item="i"/>`
,
`(_ctx, _cache) => {
return {
b: _ctx.ok,
...(_ctx.ok ? {
a: vFor(_ctx.list, i => {
return {};
})
} : {})
}
}`
)
})
// 1637
test
(
`v-if + v-for on <template>`
,
()
=>
{
assert
(
`<template v-if="ok" v-for="i in list"/>`
,
`<block wx:if="{{b}}" wx:for="{{a}}" wx:for-item="i"/>`
,
`(_ctx, _cache) => {
return {
b: _ctx.ok,
...(_ctx.ok ? {
a: vFor(_ctx.list, i => {
return {};
})
} : {})
}
}`
)
})
test
(
`v-for on element with custom directive`
,
()
=>
{
// <view v-for="i in list" v-foo/>
})
})
describe
(
'
errors
'
,
()
=>
{
...
...
@@ -446,7 +564,7 @@ return {
})
describe
(
'
prefixIdentifiers: true
'
,
()
=>
{
test
(
'
should prefix v-for source
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div
v-for="i in list"/>`
,
{
const
{
node
}
=
parseWithForTransform
(
`<
view
v-for="i in list"/>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
,
})
...
...
@@ -458,7 +576,7 @@ return {
test
(
'
should prefix v-for source w/ complex expression
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div
v-for="i in list.concat([foo])"/>`
,
`<
view
v-for="i in list.concat([foo])"/>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
expect
(
node
.
vFor
.
source
).
toMatchObject
({
...
...
@@ -476,15 +594,15 @@ return {
test
(
'
should not prefix v-for alias
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div v-for="i in list">{{ i }}{{ j }}</div
>`
,
`<
view v-for="i in list">{{ i }}{{ j }}</view
>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
const
div
=
node
as
ElementNode
expect
((
div
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
const
view
=
node
as
ElementNode
expect
((
view
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
type
:
NodeTypes
.
SIMPLE_EXPRESSION
,
content
:
`i`
,
})
expect
((
div
.
children
[
1
]
as
InterpolationNode
).
content
).
toMatchObject
({
expect
((
view
.
children
[
1
]
as
InterpolationNode
).
content
).
toMatchObject
({
type
:
NodeTypes
.
SIMPLE_EXPRESSION
,
content
:
`_ctx.j`
,
})
...
...
@@ -492,11 +610,11 @@ return {
test
(
'
should not prefix v-for aliases (multiple)
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div v-for="(i, j, k) in list">{{ i + j + k }}{{ l }}</div
>`
,
`<
view v-for="(i, j, k) in list">{{ i + j + k }}{{ l }}</view
>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
const
div
=
node
as
ElementNode
expect
((
div
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
const
view
=
node
as
ElementNode
expect
((
view
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
type
:
NodeTypes
.
COMPOUND_EXPRESSION
,
children
:
[
{
content
:
`i`
},
...
...
@@ -506,7 +624,7 @@ return {
{
content
:
`k`
},
],
})
expect
((
div
.
children
[
1
]
as
InterpolationNode
).
content
).
toMatchObject
({
expect
((
view
.
children
[
1
]
as
InterpolationNode
).
content
).
toMatchObject
({
type
:
NodeTypes
.
SIMPLE_EXPRESSION
,
content
:
`_ctx.l`
,
})
...
...
@@ -514,7 +632,7 @@ return {
test
(
'
should prefix id outside of v-for
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div><div v-for="i in list" />{{ i }}</div
>`
,
`<
view><view v-for="i in list" />{{ i }}</view
>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
expect
((
node
.
children
[
1
]
as
InterpolationNode
).
content
).
toMatchObject
({
...
...
@@ -525,9 +643,9 @@ return {
test
(
'
nested v-for
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div
v-for="i in list">
<
div v-for="i in list">{{ i + j }}</div
>{{ i }}
</
div
>`
,
`<
view
v-for="i in list">
<
view v-for="i in list">{{ i + j }}</view
>{{ i }}
</
view
>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
const
outerDiv
=
node
as
ElementNode
...
...
@@ -549,9 +667,9 @@ return {
test
(
'
v-for aliases w/ complex expressions
'
,
()
=>
{
const
{
node
}
=
parseWithForTransform
(
`<
div
v-for="({ foo = bar, baz: [qux = quux] }) in list">
`<
view
v-for="({ foo = bar, baz: [qux = quux] }) in list">
{{ foo + bar + baz + qux + quux }}
</
div
>`
,
</
view
>`
,
{
prefixIdentifiers
:
true
,
skipTransformIdentifier
:
true
}
)
expect
(
node
.
vFor
.
value
).
toMatchObject
({
...
...
@@ -568,8 +686,8 @@ return {
`] }`
,
],
})
const
div
=
node
as
ElementNode
expect
((
div
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
const
view
=
node
as
ElementNode
expect
((
view
.
children
[
0
]
as
InterpolationNode
).
content
).
toMatchObject
({
type
:
NodeTypes
.
COMPOUND_EXPRESSION
,
children
:
[
{
content
:
`foo`
},
...
...
@@ -587,8 +705,8 @@ return {
test
(
'
element v-for key expression prefixing
'
,
()
=>
{
assert
(
`<
div v-for="item in items" :key="itemKey(item)">test</div
>`
,
`<
div wx:for="{{a}}" wx:for-item="item" wx:key="a">test</div
>`
,
`<
view v-for="item in items" :key="itemKey(item)">test</view
>`
,
`<
view wx:for="{{a}}" wx:for-item="item" wx:key="a">test</view
>`
,
`(_ctx, _cache) => {
return {
a: vFor(_ctx.items, item => {
...
...
packages/uni-mp-compiler/src/transforms/transformIdentifier.ts
浏览文件 @
5485f47f
...
...
@@ -17,23 +17,37 @@ import {
NodeTransform
,
TransformContext
,
}
from
'
../transform
'
import
{
isForElementNode
}
from
'
./vFor
'
export
const
transformIdentifier
:
NodeTransform
=
(
node
,
context
)
=>
{
return
()
=>
{
if
(
node
.
type
===
NodeTypes
.
INTERPOLATION
)
{
node
.
content
=
rewriteExpression
(
node
.
content
,
context
)
}
else
if
(
node
.
type
===
NodeTypes
.
ELEMENT
)
{
const
vFor
=
isForElementNode
(
node
)
&&
node
.
vFor
for
(
let
i
=
0
;
i
<
node
.
props
.
length
;
i
++
)
{
const
dir
=
node
.
props
[
i
]
if
(
dir
.
type
===
NodeTypes
.
DIRECTIVE
)
{
const
exp
=
dir
.
exp
const
arg
=
dir
.
arg
if
(
exp
)
{
dir
.
exp
=
rewriteExpression
(
exp
,
context
)
}
if
(
arg
)
{
dir
.
arg
=
rewriteExpression
(
arg
,
context
)
}
if
(
exp
)
{
if
(
vFor
&&
arg
&&
arg
.
type
===
NodeTypes
.
SIMPLE_EXPRESSION
&&
arg
.
content
===
'
key
'
&&
exp
.
type
===
NodeTypes
.
SIMPLE_EXPRESSION
&&
exp
.
content
===
vFor
.
valueAlias
)
{
exp
.
content
=
'
*this
'
continue
}
dir
.
exp
=
rewriteExpression
(
exp
,
context
)
}
}
}
}
...
...
packages/uni-mp-compiler/src/transforms/vFor.ts
浏览文件 @
5485f47f
...
...
@@ -119,6 +119,10 @@ export const transformFor = createStructuralDirectiveTransform(
...
vForData
,
locals
:
findVForLocals
(
parseResult
),
})
const
vFor
=
{
...
vForData
,
}
;(
node
as
ForElementNode
).
vFor
=
vFor
scopes
.
vFor
++
return
()
=>
{
if
(
isTemplateNode
(
node
))
{
...
...
@@ -143,10 +147,7 @@ export const transformFor = createStructuralDirectiveTransform(
index
&&
removeIdentifiers
(
index
)
}
const
id
=
parentScope
.
id
.
next
()
;(
node
as
ForElementNode
).
vFor
=
{
sourceAlias
:
id
,
...
vForData
,
}
vFor
.
sourceAlias
=
id
parentScope
.
properties
.
push
(
createObjectProperty
(
id
,
createVForCallExpression
(
vForScope
))
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录