Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
43a38070
U
uni-app
项目概览
DCloud
/
uni-app
3 个月 前同步成功
通知
720
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,发现更多精彩内容 >>
提交
43a38070
编写于
5月 04, 2023
作者:
Y
yurj26
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(uts): transformText
上级
0b9ee282
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
139 addition
and
0 deletion
+139
-0
packages/uni-app-uts/__tests__/transforms/transformText.spec.ts
...es/uni-app-uts/__tests__/transforms/transformText.spec.ts
+30
-0
packages/uni-app-uts/src/plugins/uvue/compiler/index.ts
packages/uni-app-uts/src/plugins/uvue/compiler/index.ts
+2
-0
packages/uni-app-uts/src/plugins/uvue/compiler/transforms/transformText.ts
...uts/src/plugins/uvue/compiler/transforms/transformText.ts
+107
-0
未找到文件。
packages/uni-app-uts/__tests__/transforms/transformText.spec.ts
0 → 100644
浏览文件 @
43a38070
import
{
assert
}
from
'
../testUtils
'
describe
(
'
compiler: transform text
'
,
()
=>
{
test
(
'
transform text
'
,
()
=>
{
assert
(
`<view>hello</view>`
,
`createElementVNode("view", null, [
createElementVNode("text", null, "hello")
])`
)
assert
(
`<view><text>hello</text></view>`
,
`createElementVNode("view", null, [
createElementVNode("text", null, "hello")
])`
)
assert
(
`<view>hello{{a}}<view>aaa{{a}}</view>{{b}}</view>`
,
`createElementVNode("view", null, [
createElementVNode("text", null, "hello"),
createElementVNode("text", null, toDisplayString(_ctx.a), 1 /* TEXT */),
createElementVNode("view", null, [
createElementVNode("text", null, "aaa"),
createElementVNode("text", null, toDisplayString(_ctx.a), 1 /* TEXT */)
]),
createElementVNode("text", null, toDisplayString(_ctx.b), 1 /* TEXT */)
])`
)
})
})
packages/uni-app-uts/src/plugins/uvue/compiler/index.ts
浏览文件 @
43a38070
...
...
@@ -18,6 +18,7 @@ import { transformIf } from './transforms/vIf'
import
{
transformFor
}
from
'
./transforms/vFor
'
import
{
transformModel
}
from
'
./transforms/vModel
'
import
{
transformShow
}
from
'
./transforms/vShow
'
import
{
transformText
}
from
'
./transforms/transformText
'
export
type
TransformPreset
=
[
NodeTransform
[],
...
...
@@ -36,6 +37,7 @@ export function getBaseTransformPreset(
transformExpression
,
transformElement
,
trackSlotScopes
,
transformText
,
]
as
any
,
{
on
:
transformOn
,
...
...
packages/uni-app-uts/src/plugins/uvue/compiler/transforms/transformText.ts
0 → 100644
浏览文件 @
43a38070
import
{
isElementNode
}
from
'
@dcloudio/uni-cli-shared
'
import
{
CompoundExpressionNode
,
ElementNode
,
ElementTypes
,
InterpolationNode
,
NodeTransform
,
NodeTypes
,
TemplateChildNode
,
TextCallNode
,
TextNode
,
}
from
'
@vue/compiler-core
'
function
isTextNode
({
tag
}:
ElementNode
)
{
return
tag
===
'
text
'
||
tag
===
'
u-text
'
||
tag
===
'
button
'
}
function
isTextElement
(
node
:
TemplateChildNode
)
{
return
node
.
type
===
NodeTypes
.
ELEMENT
&&
node
.
tag
===
'
text
'
}
function
isText
(
node
:
TemplateChildNode
):
node
is
|
TextNode
|
TextCallNode
|
InterpolationNode
|
CompoundExpressionNode
{
const
{
type
}
=
node
return
(
type
===
NodeTypes
.
TEXT
||
type
===
NodeTypes
.
TEXT_CALL
||
type
===
NodeTypes
.
INTERPOLATION
||
type
===
NodeTypes
.
COMPOUND_EXPRESSION
)
}
export
const
transformText
:
NodeTransform
=
(
node
,
_
)
=>
{
if
(
!
isElementNode
(
node
))
{
return
}
if
(
isTextNode
(
node
))
{
return
}
const
{
children
}
=
node
if
(
!
children
.
length
)
{
return
}
children
.
forEach
((
child
,
index
)
=>
{
if
(
isTextElement
(
child
))
{
parseText
(
child
as
ElementNode
)
}
if
(
isText
(
child
))
{
children
.
splice
(
index
,
1
,
createText
(
node
,
child
))
}
})
}
/*
1. 转换 \\n 为 \n
2. u-text 下只能有一个文本节点(不支持 children),需要移除子组件并合并文本
*/
function
parseText
(
node
:
ElementNode
)
{
if
(
node
.
children
.
length
)
{
let
firstTextChild
for
(
let
i
=
0
;
i
<
node
.
children
.
length
;
i
++
)
{
const
child
=
node
.
children
[
i
]
if
(
isText
(
child
)
&&
typeof
(
child
as
TextNode
).
content
===
'
string
'
)
{
if
(
!
firstTextChild
)
{
firstTextChild
=
child
;(
firstTextChild
as
TextNode
).
content
=
(
firstTextChild
as
TextNode
).
content
.
replace
(
/
\\
n/g
,
'
\n
'
)
}
else
{
;(
firstTextChild
as
TextNode
).
content
+=
(
child
as
TextNode
).
content
.
replace
(
/
\\
n/g
,
'
\n
'
)
node
.
children
.
splice
(
i
,
1
)
i
--
}
}
else
if
(
child
.
type
===
1
||
child
.
type
===
3
)
{
node
.
children
.
splice
(
i
,
1
)
i
--
}
else
{
firstTextChild
=
null
}
}
}
}
function
createText
(
parent
:
ElementNode
,
node
:
TextNode
|
TextCallNode
|
InterpolationNode
|
CompoundExpressionNode
):
ElementNode
{
return
{
tag
:
'
text
'
,
type
:
NodeTypes
.
ELEMENT
,
tagType
:
ElementTypes
.
ELEMENT
,
props
:
[],
isSelfClosing
:
false
,
children
:
[
node
],
codegenNode
:
undefined
,
ns
:
parent
.
ns
,
loc
:
node
.
loc
,
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录