Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
afe4d8e3
U
uni-app
项目概览
DCloud
/
uni-app
2 个月 前同步成功
通知
716
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,发现更多精彩内容 >>
提交
afe4d8e3
编写于
9月 02, 2021
作者:
D
DCloud_LXH
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mp-baidu): for 循环移除 s-key 使用 trackBy
上级
12c02b93
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
16 addition
and
7 deletion
+16
-7
packages/uni-template-compiler/__tests__/compiler-mp-baidu.spec.js
...uni-template-compiler/__tests__/compiler-mp-baidu.spec.js
+5
-5
packages/uni-template-compiler/lib/template/traverse.js
packages/uni-template-compiler/lib/template/traverse.js
+9
-2
packages/uni-template-compiler/lib/util.js
packages/uni-template-compiler/lib/util.js
+2
-0
未找到文件。
packages/uni-template-compiler/__tests__/compiler-mp-baidu.spec.js
浏览文件 @
afe4d8e3
...
...
@@ -23,8 +23,8 @@ describe('mp:compiler-mp-baidu', () => {
})
it
(
'
generate v-for directive
'
,
()
=>
{
assertCodegen
(
'
<view><view v-for="(item,index) in items" :key="i
ndex
"></view></view>
'
,
'
<view><block s-for="
{{items}}" s-for-item="item" s-for-index="index" s-key
="index"><view></view></block></view>
'
'
<view><view v-for="(item,index) in items" :key="i
tem.id
"></view></view>
'
,
'
<view><block s-for="
items trackBy item.id" s-for-item="item" s-for-index
="index"><view></view></block></view>
'
)
})
it
(
'
generate scoped slot
'
,
()
=>
{
...
...
@@ -125,15 +125,15 @@ describe('mp:compiler-mp-baidu', () => {
)
assertCodegen
(
'
<view><Test v-for="item in items" :key="item"/></view>
'
,
'
<view><block s-for="
{{items}}" s-for-item="item" s-for-index="__i0__" s-key="*this
"><test vue-id="{{
\'
551070e6-1-
\'
+__i0__}}"></test></block></view>
'
'
<view><block s-for="
items trackBy item" s-for-item="item" s-for-index="__i0__
"><test vue-id="{{
\'
551070e6-1-
\'
+__i0__}}"></test></block></view>
'
)
assertCodegen
(
'
<view><Test v-for="item in items" :key="item"><Test v-for="item in item.items" :key="item"></Test></Test></view>
'
,
'
<view><block s-for="
{{items}}" s-for-item="item" s-for-index="__i0__" s-key="*this"><test vue-id="{{
\'
551070e6-1-
\'
+__i0__}}" vue-slots="{{[
\'
default
\'
]}}"><block s-for="{{item.items}}" s-for-item="item" s-for-index="__i1__" s-key="*this
"><test vue-id="{{(
\'
551070e6-2-
\'
+__i0__+
\'
-
\'
+__i1__)+
\'
,
\'
+(
\'
551070e6-1-
\'
+__i0__)}}"></test></block></test></block></view>
'
'
<view><block s-for="
items trackBy item" s-for-item="item" s-for-index="__i0__"><test vue-id="{{
\'
551070e6-1-
\'
+__i0__}}" vue-slots="{{[
\'
default
\'
]}}"><block s-for="item.items trackBy item" s-for-item="item" s-for-index="__i1__
"><test vue-id="{{(
\'
551070e6-2-
\'
+__i0__+
\'
-
\'
+__i1__)+
\'
,
\'
+(
\'
551070e6-1-
\'
+__i0__)}}"></test></block></test></block></view>
'
)
assertCodegen
(
'
<view><Test v-for="(item,index) in items" :key="item"><Test v-for="(item,index1) in item.items" :key="item"></Test></Test></view>
'
,
'
<view><block s-for="
{{items}}" s-for-item="item" s-for-index="index" s-key="*this"><test vue-id="{{
\'
551070e6-1-
\'
+index}}" vue-slots="{{[
\'
default
\'
]}}"><block s-for="{{item.items}}" s-for-item="item" s-for-index="index1" s-key="*this
"><test vue-id="{{(
\'
551070e6-2-
\'
+index+
\'
-
\'
+index1)+
\'
,
\'
+(
\'
551070e6-1-
\'
+index)}}"></test></block></test></block></view>
'
'
<view><block s-for="
items trackBy item" s-for-item="item" s-for-index="index"><test vue-id="{{
\'
551070e6-1-
\'
+index}}" vue-slots="{{[
\'
default
\'
]}}"><block s-for="item.items trackBy item" s-for-item="item" s-for-index="index1
"><test vue-id="{{(
\'
551070e6-2-
\'
+index+
\'
-
\'
+index1)+
\'
,
\'
+(
\'
551070e6-1-
\'
+index)}}"></test></block></test></block></view>
'
)
})
...
...
packages/uni-template-compiler/lib/template/traverse.js
浏览文件 @
afe4d8e3
...
...
@@ -428,8 +428,15 @@ function traverseRenderList (callExprNode, state) {
const
prefix
=
state
.
options
.
platform
.
directive
const
isBaidu
=
state
.
options
.
platform
.
name
===
'
mp-baidu
'
let
forValue
=
genCode
(
callExprNode
.
arguments
[
0
],
isBaidu
)
if
(
isBaidu
&&
forKey
)
{
forValue
+=
` trackBy
${
getForKey
(
forKey
,
forIndex
,
state
)}
`
}
const
attr
=
{
[
prefix
+
'
for
'
]:
genCode
(
callExprNode
.
arguments
[
0
])
,
[
prefix
+
'
for
'
]:
forValue
,
[
prefix
+
'
for-item
'
]:
forItem
}
...
...
@@ -437,7 +444,7 @@ function traverseRenderList (callExprNode, state) {
attr
[
prefix
+
'
for-index
'
]
=
forIndex
}
if
(
forKey
)
{
if
(
forKey
&&
!
isBaidu
)
{
const
key
=
getForKey
(
forKey
,
forIndex
,
state
)
if
(
key
)
{
attr
[
prefix
+
'
key
'
]
=
key
...
...
packages/uni-template-compiler/lib/util.js
浏览文件 @
afe4d8e3
...
...
@@ -107,6 +107,7 @@ function getForKey (forKey, forIndex, state) {
if
(
forKey
)
{
if
(
t
.
isIdentifier
(
forKey
))
{
if
(
forIndex
!==
forKey
.
name
)
{
// 非 forIndex
if
(
state
.
options
.
platform
.
name
===
'
mp-baidu
'
)
return
getCode
(
forKey
)
return
'
*this
'
}
else
{
// TODO
...
...
@@ -114,6 +115,7 @@ function getForKey (forKey, forIndex, state) {
return
forKey
.
name
}
}
else
if
(
t
.
isMemberExpression
(
forKey
))
{
if
(
state
.
options
.
platform
.
name
===
'
mp-baidu
'
)
return
getCode
(
forKey
)
return
forKey
.
property
.
name
||
forKey
.
property
.
value
}
else
{
state
.
tips
.
add
(
uniI18n
.
__
(
'
templateCompiler.noH5KeyNoSupportExpression
'
,
{
0
:
getCode
(
forKey
),
1
:
'
https://uniapp.dcloud.io/use?id=key
'
}))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录