Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
uni-app
提交
cf29e835
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看板
提交
cf29e835
编写于
10月 14, 2021
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
wip(mp): v-bind:class array syntax
上级
34d1e5e1
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
94 addition
and
82 deletion
+94
-82
packages/uni-mp-compiler/__tests__/style.spec.ts
packages/uni-mp-compiler/__tests__/style.spec.ts
+76
-76
packages/uni-mp-compiler/src/transforms/transformStyle.ts
packages/uni-mp-compiler/src/transforms/transformStyle.ts
+17
-5
packages/uni-mp-vue/dist/vue.runtime.esm.js
packages/uni-mp-vue/dist/vue.runtime.esm.js
+1
-1
未找到文件。
packages/uni-mp-compiler/__tests__/style.spec.ts
浏览文件 @
cf29e835
...
...
@@ -67,80 +67,80 @@ describe('compiler: transform style', () => {
}`
)
})
//
test('v-bind:style object syntax + style', () => {
//
assert(
// `<view :style="{ red: isRed }" style="foo bar
"/>`,
// `<view style="{{[a && 'red', 'foo bar']
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _ctx.isRed
}
//
}`
//
)
//
assert(
// `<view style="foo bar" :style="{ red: isRed
}"/>`,
// `<view style="{{['foo bar', a && 'red']
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _ctx.isRed
}
//
}`
//
)
//
assert(
// `<view :style="{ a: 1, b: 0, c: true, d: false, e: null, f: undefined, g: ok, h: handle(ok), i: ok>1, j, [k]:1, [l]:m, ...n, ...{a:true}, ...{b:o} }" style="foo bar
"/>`,
// `<view style="{{['a', 'c', a && 'g', b && 'h', c && 'i', d && 'j', e, g && f, h, i, j, 'foo bar']
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _ctx.ok, b: _ctx.handle(_ctx.ok), c: _ctx.ok > 1, d: _ctx.j, e: _ctx.k, f: _ctx.l, g: _ctx.m, h: _normalizeClass({ ..._ctx.n }), i: _normalizeClass({ ...{ a: true } }), j: _normalizeClass({ ...{ b: _ctx.o }
}) }
//
}`
//
)
//
assert(
// `<view style="foo bar" :style="{ a: 1, b: 0, c: true, d: false, e: null, f: undefined, g: ok, h: handle(ok), i: ok>1, j, [k]:1, [l]:m, ...n, ...{a:true}, ...{b:o}
}"/>`,
// `<view style="{{['foo bar', 'a', 'c', a && 'g', b && 'h', c && 'i', d && 'j', e, g && f, h, i, j]
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _ctx.ok, b: _ctx.handle(_ctx.ok), c: _ctx.ok > 1, d: _ctx.j, e: _ctx.k, f: _ctx.l, g: _ctx.m, h: _normalizeClass({ ..._ctx.n }), i: _normalizeClass({ ...{ a: true } }), j: _normalizeClass({ ...{ b: _ctx.o }
}) }
//
}`
//
)
//
})
//
test('v-bind:style array syntax', () => {
//
assert(
// `<view :style="[classA, class
B]"/>`,
// `<view style="{{[a, b]
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.class
B) }
//
}`
//
)
//
assert(
// `<view :style="[classA, classB, { classC: isC, classD: isD }, 'classE', isF ? 'classF' : '', isG && 'classG', ...classH, ...[classI,classJ], handle(classK
) ]"/>`,
// `<view style="{{[a, b, c, 'classE', d, e, f, g, h]
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.classB), c: _normalizeClass({ classC: _ctx.isC, classD: _ctx.isD }), d: _normalizeClass(_ctx.isF ? 'classF' : ''), e: _normalizeClass(_ctx.isG && 'classG'), f: _normalizeClass([..._ctx.classH]), g: _normalizeClass([...[_ctx.classI, _ctx.classJ]]), h: _normalizeClass(_ctx.handle(_ctx.classK
)) }
//
}`
//
)
//
})
//
test('v-bind:style array syntax + style', () => {
//
assert(
// `<view :style="[classA, classB]" style="foo bar
"/>`,
// `<view style="{{[a, b, 'foo bar']
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.class
B) }
//
}`
//
)
//
assert(
// `<view style="foo bar" :style="[classA, class
B]"/>`,
// `<view style="{{['foo bar', a, b]
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.class
B) }
//
}`
//
)
//
assert(
// `<view :style="[classA, classB, { classC: isC, classD: isD }, 'classE', isF ? 'classF' : '', isG && 'classG', ...classH, ...[classI,classJ], handle(classK) ]" style="foo bar
"/>`,
// `<view style="{{[a, b, c, 'classE', d, e, f, g, h, 'foo bar']
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.classB), c: _normalizeClass({ classC: _ctx.isC, classD: _ctx.isD }), d: _normalizeClass(_ctx.isF ? 'classF' : ''), e: _normalizeClass(_ctx.isG && 'classG'), f: _normalizeClass([..._ctx.classH]), g: _normalizeClass([...[_ctx.classI, _ctx.classJ]]), h: _normalizeClass(_ctx.handle(_ctx.classK
)) }
//
}`
//
)
//
assert(
// `<view style="foo bar" :style="[classA, classB, { classC: isC, classD: isD }, 'classE', isF ? 'classF' : '', isG && 'classG', ...classH, ...[classI,classJ], handle(classK
) ]"/>`,
// `<view style="{{['foo bar', a, b, c, 'classE', d, e, f, g, h]
}}"/>`,
//
`(_ctx, _cache) => {
// return { a: _normalizeClass(_ctx.classA), b: _normalizeClass(_ctx.classB), c: _normalizeClass({ classC: _ctx.isC, classD: _ctx.isD }), d: _normalizeClass(_ctx.isF ? 'classF' : ''), e: _normalizeClass(_ctx.isG && 'classG'), f: _normalizeClass([..._ctx.classH]), g: _normalizeClass([...[_ctx.classI, _ctx.classJ]]), h: _normalizeClass(_ctx.handle(_ctx.classK
)) }
//
}`
//
)
//
})
test
(
'
v-bind:style object syntax + style
'
,
()
=>
{
assert
(
`<view :style="{ color: 'green' }" style="font-size:15px
"/>`
,
`<view style="{{'color:' + 'green' + ';' + 'font-size:15px'
}}"/>`
,
`(_ctx, _cache) => {
return {
}
}`
)
assert
(
`<view style="font-size:15px" :style="{ color: 'green'
}"/>`
,
`<view style="{{'font-size:15px' + ';' + ('color:' + 'green')
}}"/>`
,
`(_ctx, _cache) => {
return {
}
}`
)
assert
(
`<view :style="{color:'green',fontSize:'15px',backgroundColor: handle(bg),fontWeight,[padding]:box.padding,...style,...{margin:'0px'}}" style="font-size:15px
"/>`
,
`<view style="{{'color:' + 'green' + ';' + ('font-size:' + '15px') + ';' + ('background-color:' + a) + ';' + ('font-weight:' + b) + ';' + (c + ':' + d) + ';' + e + ';' + f + ';' + 'font-size:15px'
}}"/>`
,
`(_ctx, _cache) => {
return { a: _ctx.handle(_ctx.bg), b: _ctx.fontWeight, c: _hyphenate(_ctx.padding), d: _ctx.box.padding, e: _normalizeStyle(_ctx.style), f: _normalizeStyle({ margin: '0px'
}) }
}`
)
assert
(
`<view style="font-size:15px" :style="{color:'green',fontSize:'15px',backgroundColor: handle(bg),fontWeight,[padding]:box.padding,...style,...{margin:'0px'}
}"/>`
,
`<view style="{{'font-size:15px' + ';' + ('color:' + 'green' + ';' + ('font-size:' + '15px') + ';' + ('background-color:' + a) + ';' + ('font-weight:' + b) + ';' + (c + ':' + d) + ';' + e + ';' + f)
}}"/>`
,
`(_ctx, _cache) => {
return { a: _ctx.handle(_ctx.bg), b: _ctx.fontWeight, c: _hyphenate(_ctx.padding), d: _ctx.box.padding, e: _normalizeStyle(_ctx.style), f: _normalizeStyle({ margin: '0px'
}) }
}`
)
})
test
(
'
v-bind:style array syntax
'
,
()
=>
{
assert
(
`<view :style="[styleA, style
B]"/>`
,
`<view style="{{a + ';' + b
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.style
B) }
}`
)
assert
(
`<view :style="[styleA, styleB, { color:'red',fontSize }, 'font-weight:bold', ...styleC, ...[styleD,styleE], handle(styleF
) ]"/>`
,
`<view style="{{a + ';' + b + ';' + c + ';' + 'font-weight:bold' + ';' + d + ';' + e + ';' + f
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.styleB), c: _normalizeStyle({ color: 'red', fontSize: _ctx.fontSize }), d: _normalizeStyle(_ctx.styleC), e: _normalizeStyle([_ctx.styleD, _ctx.styleE]), f: _normalizeStyle(_ctx.handle(_ctx.styleF
)) }
}`
)
})
test
(
'
v-bind:style array syntax + style
'
,
()
=>
{
assert
(
`<view :style="[styleA, styleB]" style="font-size:15px
"/>`
,
`<view style="{{a + ';' + b + ';' + 'font-size:15px'
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.style
B) }
}`
)
assert
(
`<view style="font-size:15px" :style="[styleA, style
B]"/>`
,
`<view style="{{'font-size:15px' + ';' + (a + ';' + b)
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.style
B) }
}`
)
assert
(
`<view :style="[styleA, styleB, { color:'red',fontSize }, 'font-weight:bold', ...styleC, ...[styleD,styleE], handle(styleF) ]" style="font-size:15px
"/>`
,
`<view style="{{a + ';' + b + ';' + c + ';' + 'font-weight:bold' + ';' + d + ';' + e + ';' + f + ';' + 'font-size:15px'
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.styleB), c: _normalizeStyle({ color: 'red', fontSize: _ctx.fontSize }), d: _normalizeStyle(_ctx.styleC), e: _normalizeStyle([_ctx.styleD, _ctx.styleE]), f: _normalizeStyle(_ctx.handle(_ctx.styleF
)) }
}`
)
assert
(
`<view style="font-size:15px" :style="[styleA, styleB, { color:'red',fontSize }, 'font-weight:bold', ...styleC, ...[styleD,styleE], handle(styleF
) ]"/>`
,
`<view style="{{'font-size:15px' + ';' + (a + ';' + b + ';' + c + ';' + 'font-weight:bold' + ';' + d + ';' + e + ';' + f)
}}"/>`
,
`(_ctx, _cache) => {
return { a: _normalizeStyle(_ctx.styleA), b: _normalizeStyle(_ctx.styleB), c: _normalizeStyle({ color: 'red', fontSize: _ctx.fontSize }), d: _normalizeStyle(_ctx.styleC), e: _normalizeStyle([_ctx.styleD, _ctx.styleE]), f: _normalizeStyle(_ctx.handle(_ctx.styleF
)) }
}`
)
})
})
packages/uni-mp-compiler/src/transforms/transformStyle.ts
浏览文件 @
cf29e835
...
...
@@ -12,6 +12,7 @@ import {
isLiteral
,
isObjectProperty
,
binaryExpression
,
isIdentifier
,
}
from
'
@babel/types
'
import
{
DirectiveNode
,
...
...
@@ -118,13 +119,12 @@ function rewriteStyleArrayExpression(
)
{
expr
.
elements
.
forEach
((
prop
,
index
)
=>
{
if
(
!
isStringLiteral
(
prop
))
{
const
code
=
genBabelExpr
(
arrayExpression
([
prop
]))
const
code
=
genBabelExpr
(
arrayExpression
([
isSpreadElement
(
prop
)
?
prop
.
argument
:
prop
])
)
expr
.
elements
[
index
]
=
identifier
(
rewriteStyleExpression
(
createSimpleExpression
(
isSpreadElement
(
prop
)
?
code
:
code
.
slice
(
1
,
-
1
),
false
),
createSimpleExpression
(
code
.
slice
(
1
,
-
1
),
false
),
context
).
content
)
...
...
@@ -187,6 +187,18 @@ function createBinaryExpression(left: Expression, right: Expression) {
function
createStyleBindingByArrayExpression
(
expr
:
ArrayExpression
)
{
let
result
:
Expression
|
undefined
function
concat
(
expr
:
Expression
)
{
if
(
!
result
)
{
result
=
expr
}
else
{
result
=
createBinaryExpression
(
addSemicolon
(
result
),
expr
)
}
}
expr
.
elements
.
forEach
((
prop
)
=>
{
if
(
isStringLiteral
(
prop
)
||
isIdentifier
(
prop
))
{
concat
(
prop
)
}
})
return
result
}
...
...
packages/uni-mp-vue/dist/vue.runtime.esm.js
浏览文件 @
cf29e835
import
{
extend
,
isSymbol
,
isObject
,
toRawType
,
def
,
hasChanged
,
isArray
,
isFunction
,
NOOP
,
remove
,
toHandlerKey
,
camelize
,
capitalize
,
isString
,
normalizeClass
,
normalizeStyle
,
isOn
,
isPromise
,
EMPTY_OBJ
,
isSet
,
isMap
,
isPlainObject
,
invokeArrayFns
,
hasOwn
,
NO
,
isIntegerKey
,
toNumber
,
hyphenate
,
isReservedProp
,
EMPTY_ARR
,
makeMap
,
toTypeString
}
from
'
@vue/shared
'
;
export
{
camelize
,
normalizeClass
,
normalizeProps
,
normalizeStyle
,
toDisplayString
,
toHandlerKey
}
from
'
@vue/shared
'
;
export
{
camelize
,
hyphenate
,
normalizeClass
,
normalizeProps
,
normalizeStyle
,
toDisplayString
,
toHandlerKey
}
from
'
@vue/shared
'
;
// lifecycle
// App and Page
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录