Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
luomor
uni-app
提交
7459c1f1
uni-app
项目概览
luomor
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7459c1f1
编写于
7月 10, 2020
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 解决部分组件写法导致编译报错的问题 question/101132
上级
a890781d
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
105 addition
and
1 deletion
+105
-1
packages/webpack-uni-mp-loader/__tests__/components.spec.js
packages/webpack-uni-mp-loader/__tests__/components.spec.js
+62
-0
packages/webpack-uni-mp-loader/lib/babel/scoped-component-traverse.js
...pack-uni-mp-loader/lib/babel/scoped-component-traverse.js
+43
-1
未找到文件。
packages/webpack-uni-mp-loader/__tests__/components.spec.js
浏览文件 @
7459c1f1
...
...
@@ -187,6 +187,68 @@ global['__wxVueOptions'] = {
}
)
assertCodegenOptions
(
`const options = {
name: 'test'
}
export default options`
,
{
name
:
'
"test"
'
,
inheritAttrs
:
null
,
props
:
null
}
)
assertCodegenOptions
(
`let options
options = {
name: 'test'
}
export default options`
,
{
name
:
'
"test"
'
,
inheritAttrs
:
null
,
props
:
null
}
)
assertCodegenOptions
(
`const options = Vue.extend({
name: 'test'
})
export default options`
,
{
name
:
'
"test"
'
,
inheritAttrs
:
null
,
props
:
null
}
)
assertCodegenOptions
(
`let options
options = Vue.extend({
name: 'test'
})
export default options`
,
{
name
:
'
"test"
'
,
inheritAttrs
:
null
,
props
:
null
}
)
assertCodegenOptions
(
`const options = {
name: 'test'
}
export default Vue.extend(options)`
,
{
name
:
'
"test"
'
,
inheritAttrs
:
null
,
props
:
null
}
)
assertCodegenOptions
(
`export default {
props: ['id', 'test']
...
...
packages/webpack-uni-mp-loader/lib/babel/scoped-component-traverse.js
浏览文件 @
7459c1f1
...
...
@@ -60,6 +60,41 @@ function handleComponentsObjectExpression (componentsObjExpr, path, state, prepe
state
.
components
=
prepend
?
components
.
concat
(
state
.
components
)
:
components
}
function
handleIdentifier
({
name
},
path
,
state
)
{
// 仅做有限查找
for
(
let
i
=
path
.
container
.
length
;
i
>
0
;
i
--
)
{
const
node
=
path
.
container
[
i
-
1
]
let
declarations
=
[]
if
(
t
.
isExpressionStatement
(
node
))
{
declarations
=
[
node
]
}
else
if
(
t
.
isVariableDeclaration
(
node
))
{
declarations
=
node
.
declarations
}
for
(
let
i
=
declarations
.
length
;
i
>
0
;
i
--
)
{
let
declaration
=
declarations
[
i
-
1
]
let
identifier
if
(
t
.
isVariableDeclarator
(
declaration
))
{
identifier
=
declaration
.
id
declaration
=
declaration
.
init
}
else
if
(
t
.
isExpressionStatement
(
declaration
))
{
identifier
=
declaration
.
expression
.
left
declaration
=
declaration
.
expression
.
right
}
if
(
identifier
.
name
===
name
)
{
if
(
t
.
isCallExpression
(
declaration
)
&&
t
.
isMemberExpression
(
declaration
.
callee
)
&&
declaration
.
arguments
.
length
===
1
)
{
declaration
=
declaration
.
arguments
[
0
]
}
if
(
t
.
isObjectExpression
(
declaration
))
{
handleObjectExpression
(
declaration
,
path
,
state
)
}
return
}
}
}
}
module
.
exports
=
function
(
ast
,
state
=
{
type
:
'
Component
'
,
components
:
[],
...
...
@@ -96,12 +131,19 @@ module.exports = function (ast, state = {
const
declaration
=
path
.
node
.
declaration
if
(
t
.
isObjectExpression
(
declaration
))
{
// export default {components:{}}
handleObjectExpression
(
declaration
,
path
,
state
)
}
else
if
(
t
.
isIdentifier
(
declaration
))
{
handleIdentifier
(
declaration
,
path
,
state
)
}
else
if
(
t
.
isCallExpression
(
declaration
)
&&
t
.
isMemberExpression
(
declaration
.
callee
)
&&
declaration
.
arguments
.
length
===
1
)
{
// export default Vue.extend({components:{}})
if
(
declaration
.
callee
.
object
.
name
===
'
Vue
'
&&
declaration
.
callee
.
property
.
name
===
'
extend
'
)
{
handleObjectExpression
(
declaration
.
arguments
[
0
],
path
,
state
)
const
argument
=
declaration
.
arguments
[
0
]
if
(
t
.
isObjectExpression
(
argument
))
{
handleObjectExpression
(
argument
,
path
,
state
)
}
else
if
(
t
.
isIdentifier
(
argument
))
{
handleIdentifier
(
argument
,
path
,
state
)
}
}
}
else
if
(
t
.
isClassDeclaration
(
declaration
)
&&
declaration
.
decorators
&&
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录