Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wzj-java
uni-app
提交
d07d1359
U
uni-app
项目概览
wzj-java
/
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,发现更多精彩内容 >>
提交
d07d1359
编写于
4月 20, 2022
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mp-weixin): Components start with wx (#3451)
上级
4791a571
变更
10
隐藏空白更改
内联
并排
Showing
10 changed file
with
102 addition
and
18 deletion
+102
-18
packages/uni-cli-shared/__tests__/usingComponents.spec.ts
packages/uni-cli-shared/__tests__/usingComponents.spec.ts
+10
-1
packages/uni-cli-shared/src/mp/template.ts
packages/uni-cli-shared/src/mp/template.ts
+4
-0
packages/uni-cli-shared/src/mp/usingComponents.ts
packages/uni-cli-shared/src/mp/usingComponents.ts
+35
-9
packages/uni-mp-compiler/src/template/codegen.ts
packages/uni-mp-compiler/src/template/codegen.ts
+3
-0
packages/uni-mp-vite/src/index.ts
packages/uni-mp-vite/src/index.ts
+9
-2
packages/uni-mp-vite/src/plugins/mainJs.ts
packages/uni-mp-vite/src/plugins/mainJs.ts
+7
-1
packages/uni-mp-vite/src/plugins/usingComponents.ts
packages/uni-mp-vite/src/plugins/usingComponents.ts
+21
-4
packages/uni-mp-weixin/__tests__/component.spec.ts
packages/uni-mp-weixin/__tests__/component.spec.ts
+9
-0
packages/uni-mp-weixin/dist/uni.compiler.js
packages/uni-mp-weixin/dist/uni.compiler.js
+2
-1
packages/uni-mp-weixin/src/compiler/options.ts
packages/uni-mp-weixin/src/compiler/options.ts
+2
-0
未找到文件。
packages/uni-cli-shared/__tests__/usingComponents.spec.ts
浏览文件 @
d07d1359
...
...
@@ -10,6 +10,9 @@ import {
}
from
'
../src/mp/usingComponents
'
const
inputDir
=
'
/usr/xxx/projects/test/src
'
function
normalizeComponentName
(
name
:
string
)
{
return
name
}
async
function
resolve
(
id
:
string
,
importer
?:
string
)
{
return
{
id
:
importer
?
path
.
resolve
(
path
.
dirname
(
importer
),
id
)
:
id
,
...
...
@@ -44,6 +47,7 @@ export function createApp() {
{
inputDir
,
resolve
,
normalizeComponentName
,
}
)
...
...
@@ -88,6 +92,7 @@ export function createApp() {
{
inputDir
,
resolve
,
normalizeComponentName
,
}
)
...
...
@@ -118,7 +123,11 @@ export function createApp() {
)
{
const
ast
=
parseProgram
(
source
,
filename
,
{})
const
{
imports
}
=
await
parseMainDescriptor
(
filename
,
ast
,
resolve
)
updateMiniProgramComponentsByMainFilename
(
filename
,
inputDir
)
updateMiniProgramComponentsByMainFilename
(
filename
,
inputDir
,
normalizeComponentName
)
expect
(
findUsingComponents
(
'
pages/index/index
'
)).
toMatchObject
(
usingComponents
)
...
...
packages/uni-cli-shared/src/mp/template.ts
浏览文件 @
d07d1359
...
...
@@ -53,6 +53,10 @@ export interface MiniProgramCompilerOptions {
* 父组件 setData 后,子组件的 properties 是否可以同步获取,目前仅 mp-weixin,mp-qq,mp-alipay 支持
*/
getPropertySync
?:
boolean
/**
* 格式化组件名称,比如 wx-btn => weixin-btn (微信不允许以 wx 命名自定义组件)
*/
normalizeName
?:
(
name
:
string
)
=>
string
}
directive
:
str
ing
emitFile
?:
(
emittedFile
:
EmittedAsset
)
=>
string
...
...
packages/uni-cli-shared/src/mp/usingComponents.ts
浏览文件 @
d07d1359
...
...
@@ -117,21 +117,31 @@ export async function parseMainDescriptor(
export
function
updateMiniProgramComponentsByScriptFilename
(
scriptFilename
:
string
,
inputDir
:
string
inputDir
:
string
,
normalizeComponentName
:
(
name
:
string
)
=>
string
)
{
const
mainFilename
=
findMainFilenameByScriptFilename
(
scriptFilename
)
if
(
mainFilename
)
{
updateMiniProgramComponentsByMainFilename
(
mainFilename
,
inputDir
)
updateMiniProgramComponentsByMainFilename
(
mainFilename
,
inputDir
,
normalizeComponentName
)
}
}
export
function
updateMiniProgramComponentsByTemplateFilename
(
templateFilename
:
string
,
inputDir
:
string
inputDir
:
string
,
normalizeComponentName
:
(
name
:
string
)
=>
string
)
{
const
mainFilename
=
findMainFilenameByTemplateFilename
(
templateFilename
)
if
(
mainFilename
)
{
updateMiniProgramComponentsByMainFilename
(
mainFilename
,
inputDir
)
updateMiniProgramComponentsByMainFilename
(
mainFilename
,
inputDir
,
normalizeComponentName
)
}
}
...
...
@@ -153,9 +163,11 @@ export async function updateMiniProgramGlobalComponents(
{
inputDir
,
resolve
,
normalizeComponentName
,
}:
{
inputDir
:
string
resolve
:
ParseDescriptor
[
'
resolve
'
]
normalizeComponentName
:
(
name
:
string
)
=>
string
}
)
{
const
{
bindingComponents
,
imports
}
=
await
parseGlobalDescriptor
(
...
...
@@ -165,7 +177,12 @@ export async function updateMiniProgramGlobalComponents(
)
addMiniProgramUsingComponents
(
'
app
'
,
createUsingComponents
(
bindingComponents
,
imports
,
inputDir
)
createUsingComponents
(
bindingComponents
,
imports
,
inputDir
,
normalizeComponentName
)
)
return
{
imports
,
...
...
@@ -175,7 +192,8 @@ export async function updateMiniProgramGlobalComponents(
function
createUsingComponents
(
bindingComponents
:
BindingComponents
,
imports
:
ImportDeclaration
[],
inputDir
:
string
inputDir
:
string
,
normalizeComponentName
:
(
name
:
string
)
=>
string
)
{
const
usingComponents
:
Record
<
string
,
string
>
=
{}
imports
.
forEach
(({
source
:
{
value
},
specifiers
:
[
specifier
]
})
=>
{
...
...
@@ -183,7 +201,9 @@ function createUsingComponents(
if
(
!
bindingComponents
[
name
])
{
return
}
const
componentName
=
hyphenate
(
bindingComponents
[
name
].
tag
)
const
componentName
=
normalizeComponentName
(
hyphenate
(
bindingComponents
[
name
].
tag
)
)
if
(
!
usingComponents
[
componentName
])
{
usingComponents
[
componentName
]
=
addLeadingSlash
(
removeExt
(
normalizeMiniProgramFilename
(
value
,
inputDir
))
...
...
@@ -195,7 +215,8 @@ function createUsingComponents(
export
function
updateMiniProgramComponentsByMainFilename
(
mainFilename
:
string
,
inputDir
:
string
inputDir
:
string
,
normalizeComponentName
:
(
name
:
string
)
=>
string
)
{
const
mainDescriptor
=
mainDescriptors
.
get
(
mainFilename
)
if
(
!
mainDescriptor
)
{
...
...
@@ -221,7 +242,12 @@ export function updateMiniProgramComponentsByMainFilename(
addMiniProgramUsingComponents
(
removeExt
(
normalizeMiniProgramFilename
(
mainFilename
,
inputDir
)),
createUsingComponents
(
bindingComponents
,
imports
,
inputDir
)
createUsingComponents
(
bindingComponents
,
imports
,
inputDir
,
normalizeComponentName
)
)
}
...
...
packages/uni-mp-compiler/src/template/codegen.ts
浏览文件 @
d07d1359
...
...
@@ -335,6 +335,9 @@ function genElement(node: ElementNode, context: TemplateCodegenContext) {
}
if
(
isUserComponent
(
node
,
context
))
{
tag
=
hyphenate
(
tag
)
if
(
context
.
component
?.
normalizeName
)
{
tag
=
context
.
component
?.
normalizeName
(
tag
)
}
}
const
{
push
}
=
context
...
...
packages/uni-mp-vite/src/index.ts
浏览文件 @
d07d1359
...
...
@@ -22,11 +22,15 @@ export default (options: UniMiniProgramPluginOptions) => {
if
(
!
options
.
app
.
plugins
)
{
delete
process
.
env
.
UNI_MP_PLUGIN
}
const
normalizeComponentName
=
options
.
template
.
component
?.
normalizeName
return
[
(
options
:
{
vueOptions
?:
{
script
?:
Partial
<
SFCScriptCompileOptions
>
}
})
=>
{
return
uniMainJsPlugin
(
options
.
vueOptions
?.
script
)
return
uniMainJsPlugin
({
normalizeComponentName
,
babelParserPlugins
:
options
.
vueOptions
?.
script
?.
babelParserPlugins
,
})
},
uniManifestJsonPlugin
(
options
),
uniPagesJsonPlugin
(
options
),
...
...
@@ -38,7 +42,10 @@ export default (options: UniMiniProgramPluginOptions) => {
(
options
:
{
vueOptions
?:
{
script
?:
Partial
<
SFCScriptCompileOptions
>
}
})
=>
{
return
uniUsingComponentsPlugin
(
options
.
vueOptions
?.
script
)
return
uniUsingComponentsPlugin
({
normalizeComponentName
,
babelParserPlugins
:
options
.
vueOptions
?.
script
?.
babelParserPlugins
,
})
},
...(
process
.
env
.
UNI_SUBPACKAGE
?
[
uniSubpackagePlugin
(
options
)]
:
[]),
...(
process
.
env
.
UNI_MP_PLUGIN
?
[
uniMiniProgramPluginPlugin
(
options
)]
:
[]),
...
...
packages/uni-mp-vite/src/plugins/mainJs.ts
浏览文件 @
d07d1359
...
...
@@ -10,8 +10,13 @@ import type { SFCScriptCompileOptions } from '@vue/compiler-sfc'
import
{
dynamicImport
}
from
'
./usingComponents
'
export
function
uniMainJsPlugin
(
options
:
Partial
<
SFCScriptCompileOptions
>
=
{}
options
:
{
normalizeComponentName
?:
(
name
:
string
)
=>
string
babelParserPlugins
?:
SFCScriptCompileOptions
[
'
babelParserPlugins
'
]
}
=
{}
)
{
const
normalizeComponentName
=
options
.
normalizeComponentName
||
((
name
:
string
)
=>
name
)
return
defineUniMainJsPlugin
((
opts
)
=>
{
return
{
name
:
'
uni:mp-main-js
'
,
...
...
@@ -31,6 +36,7 @@ export function uniMainJsPlugin(
{
inputDir
,
resolve
:
this
.
resolve
,
normalizeComponentName
,
}
)
const
{
code
,
map
}
=
await
transformDynamicImports
(
source
,
imports
,
{
...
...
packages/uni-mp-vite/src/plugins/usingComponents.ts
浏览文件 @
d07d1359
...
...
@@ -18,8 +18,13 @@ import {
import
{
virtualComponentPath
,
virtualPagePath
}
from
'
./entry
'
export
function
uniUsingComponentsPlugin
(
options
:
Partial
<
SFCScriptCompileOptions
>
=
{}
options
:
{
normalizeComponentName
?:
(
name
:
string
)
=>
string
babelParserPlugins
?:
SFCScriptCompileOptions
[
'
babelParserPlugins
'
]
}
=
{}
):
Plugin
{
const
normalizeComponentName
=
options
.
normalizeComponentName
||
((
name
:
string
)
=>
name
)
const
parseAst
=
(
source
:
string
,
id
:
string
)
=>
{
return
parseProgram
(
source
,
id
,
{
babelParserPlugins
:
options
.
babelParserPlugins
,
...
...
@@ -56,7 +61,11 @@ export function uniUsingComponentsPlugin(
isExternal
:
true
,
}
)
updateMiniProgramComponentsByScriptFilename
(
filename
,
inputDir
)
updateMiniProgramComponentsByScriptFilename
(
filename
,
inputDir
,
normalizeComponentName
)
return
transformDynamicImports
(
source
,
descriptor
.
imports
,
...
...
@@ -73,7 +82,11 @@ export function uniUsingComponentsPlugin(
isExternal
:
true
,
}
)
updateMiniProgramComponentsByTemplateFilename
(
filename
,
inputDir
)
updateMiniProgramComponentsByTemplateFilename
(
filename
,
inputDir
,
normalizeComponentName
)
return
transformDynamicImports
(
source
,
descriptor
.
imports
,
...
...
@@ -90,7 +103,11 @@ export function uniUsingComponentsPlugin(
const
descriptor
=
await
parseMainDescriptor
(
filename
,
ast
,
this
.
resolve
)
updateMiniProgramComponentsByMainFilename
(
filename
,
inputDir
)
updateMiniProgramComponentsByMainFilename
(
filename
,
inputDir
,
normalizeComponentName
)
return
transformDynamicImports
(
source
,
...
...
packages/uni-mp-weixin/__tests__/component.spec.ts
浏览文件 @
d07d1359
import
{
assert
}
from
'
./testUtils
'
import
{
customElements
}
from
'
../src/compiler/options
'
describe
(
'
mp-weixin: transform component
'
,
()
=>
{
test
(
`Components start with wx`
,
()
=>
{
assert
(
`<WxBtn/>`
,
`<weixin-btn u-i="2a9ec0b0-0" bind:__l="__l"/>`
,
`(_ctx, _cache) => {
return {}
}`
)
})
test
(
`component with v-show`
,
()
=>
{
assert
(
`<custom v-show="ok"/>`
,
...
...
packages/uni-mp-weixin/dist/uni.compiler.js
浏览文件 @
d07d1359
...
...
@@ -100,7 +100,8 @@ const miniProgram = {
component
:
{
dir
:
COMPONENTS_DIR
,
vShow
:
uniCliShared
.
COMPONENT_CUSTOM_HIDDEN
,
getPropertySync
:
false
,
// 为了避免 Setting data field "uP" to undefined is invalid 警告
getPropertySync
:
false
,
normalizeName
:
(
name
)
=>
name
.
startsWith
(
'
wx-
'
)
?
name
.
replace
(
'
wx-
'
,
'
weixin-
'
)
:
name
,
},
};
const
projectConfigFilename
=
'
project.config.json
'
;
...
...
packages/uni-mp-weixin/src/compiler/options.ts
浏览文件 @
d07d1359
...
...
@@ -57,6 +57,8 @@ export const miniProgram: MiniProgramCompilerOptions = {
dir
:
COMPONENTS_DIR
,
vShow
:
COMPONENT_CUSTOM_HIDDEN
,
getPropertySync
:
false
,
// 为了避免 Setting data field "uP" to undefined is invalid 警告
normalizeName
:
(
name
)
=>
name
.
startsWith
(
'
wx-
'
)
?
name
.
replace
(
'
wx-
'
,
'
weixin-
'
)
:
name
,
},
}
const
projectConfigFilename
=
'
project.config.json
'
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录