Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
20岁爱吃必胜客
uni-app
提交
e42ead51
U
uni-app
项目概览
20岁爱吃必胜客
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
0
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,发现更多精彩内容 >>
提交
e42ead51
编写于
10月 14, 2022
作者:
fxy060608
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(uni_modules): support exports
上级
037722d6
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
134 addition
and
12 deletion
+134
-12
.eslintignore
.eslintignore
+2
-1
packages/uni-cli-shared/lib/index.js
packages/uni-cli-shared/lib/index.js
+3
-2
packages/uni-cli-shared/lib/uni_modules-loader.js
packages/uni-cli-shared/lib/uni_modules-loader.js
+8
-0
packages/uni-cli-shared/lib/uni_modules/uni_modules.js
packages/uni-cli-shared/lib/uni_modules/uni_modules.js
+109
-0
packages/vue-cli-plugin-uni/lib/app-plus/index.js
packages/vue-cli-plugin-uni/lib/app-plus/index.js
+5
-4
packages/vue-cli-plugin-uni/lib/h5/index.js
packages/vue-cli-plugin-uni/lib/h5/index.js
+4
-3
packages/vue-cli-plugin-uni/lib/mp/index.js
packages/vue-cli-plugin-uni/lib/mp/index.js
+3
-2
未找到文件。
.eslintignore
浏览文件 @
e42ead51
...
...
@@ -39,4 +39,5 @@ uni-polyfill.js
packages/uni-cli-shared/components/ad-fullscreen-video.vue
packages/uni-cli-shared/components/ad-interactive.vue
packages/uni-cli-shared/components/ad-interstitial.vue
packages/uni-cli-shared/components/ad-rewarded-video.vue
packages/uni-cli-shared/components/ad-rewarded-video.vue
packages/uni-cli-shared/lib/uni_modules/uni_modules.js
packages/uni-cli-shared/lib/index.js
浏览文件 @
e42ead51
...
...
@@ -112,5 +112,6 @@ module.exports = {
getPlatformGlobal
,
getPlatformStat
,
getPlatformPush
,
getPlatformUniCloud
}
getPlatformUniCloud
,
uniModulesLoader
:
normalizePath
(
require
.
resolve
(
'
./uni_modules-loader
'
))
}
packages/uni-cli-shared/lib/uni_modules-loader.js
0 → 100644
浏览文件 @
e42ead51
const
{
genUniModulesExports
}
=
require
(
'
./uni_modules/uni_modules
'
)
module
.
exports
=
function
()
{
this
.
cacheable
&&
this
.
cacheable
()
return
genUniModulesExports
()
}
packages/uni-cli-shared/lib/uni_modules/uni_modules.js
0 → 100644
浏览文件 @
e42ead51
'
use strict
'
var
__importDefault
=
(
this
&&
this
.
__importDefault
)
||
function
(
mod
)
{
return
(
mod
&&
mod
.
__esModule
)
?
mod
:
{
default
:
mod
}
}
Object
.
defineProperty
(
exports
,
'
__esModule
'
,
{
value
:
true
})
exports
.
parseDefines
=
exports
.
parseExports
=
exports
.
genUniModulesExports
=
void
0
const
path_1
=
__importDefault
(
require
(
'
path
'
))
const
fs_extra_1
=
__importDefault
(
require
(
'
fs-extra
'
))
const
merge_1
=
require
(
'
merge
'
)
function
genUniModulesExports
()
{
const
uniModulesDir
=
path_1
.
default
.
resolve
(
process
.
env
.
UNI_INPUT_DIR
,
'
uni_modules
'
)
if
(
!
fs_extra_1
.
default
.
existsSync
(
uniModulesDir
))
{
return
''
}
const
importCodes
=
[]
const
assignCodes
=
[]
fs_extra_1
.
default
.
readdirSync
(
uniModulesDir
).
forEach
((
uniModuleDir
)
=>
{
var
_a
,
_b
const
pkgPath
=
path_1
.
default
.
resolve
(
uniModulesDir
,
uniModuleDir
,
'
package.json
'
)
if
(
!
fs_extra_1
.
default
.
existsSync
(
pkgPath
))
{
return
}
const
exports
=
(
_b
=
(
_a
=
JSON
.
parse
(
fs_extra_1
.
default
.
readFileSync
(
pkgPath
,
'
utf8
'
)))
===
null
||
_a
===
void
0
?
void
0
:
_a
.
uni_modules
)
===
null
||
_b
===
void
0
?
void
0
:
_b
.
exports
if
(
exports
)
{
const
[
exportsImportCodes
,
exportsAssignCodes
]
=
parseExports
(
process
.
env
.
UNI_PLATFORM
===
'
h5
'
?
'
web
'
:
process
.
env
.
UNI_PLATFORM
,
`@/uni_modules/
${
uniModuleDir
}
`
,
exports
)
importCodes
.
push
(...
exportsImportCodes
)
assignCodes
.
push
(...
exportsAssignCodes
)
}
})
if
(
!
importCodes
.
length
)
{
return
''
}
return
`
${
importCodes
.
join
(
'
\n
'
)}
${
assignCodes
.
join
(
'
\n
'
)}
`
}
exports
.
genUniModulesExports
=
genUniModulesExports
function
parseExports
(
platform
,
source
,
exports
=
{})
{
const
rootDefines
=
{}
Object
.
keys
(
exports
).
forEach
((
name
)
=>
{
if
(
name
.
startsWith
(
'
uni
'
))
{
rootDefines
[
name
]
=
exports
[
name
]
}
})
const
platformDefines
=
exports
[
platform
]
// 该平台不支持
if
(
platformDefines
===
false
)
{
return
[[],
[]]
}
return
parseDefines
(
source
,
(
0
,
merge_1
.
recursive
)(
true
,
rootDefines
,
platformDefines
))
}
exports
.
parseExports
=
parseExports
function
parseDefines
(
source
,
defines
=
{})
{
const
importCodes
=
[]
const
assignCodes
=
[]
Object
.
keys
(
defines
).
forEach
((
name
)
=>
{
const
[
defineImportCodes
,
defineAssignCodes
]
=
parseDefine
(
source
,
name
,
defines
[
name
])
importCodes
.
push
(...
defineImportCodes
)
assignCodes
.
push
(...
defineAssignCodes
)
})
return
[
importCodes
,
assignCodes
]
}
exports
.
parseDefines
=
parseDefines
/**
* uni:'getBatteryInfo'
* import getBatteryInfo from '..'
*
* uni:['getBatteryInfo']
* import { getBatteryInfo } from '..'
*
* uni:['openLocation','chooseLocation']
* import { openLocation, chooseLocation } from '..'
*
* uni:{
* onUserCaptureScreen: "onCaptureScreen"
* offUserCaptureScreen: "offCaptureScreen"
* }
*
* uni.getBatteryInfo = getBatteryInfo
* @param source
* @param globalObject
* @param define
* @returns
*/
function
parseDefine
(
source
,
globalObject
,
define
)
{
const
importCodes
=
[]
const
assignCodes
=
[]
if
(
typeof
define
===
'
string
'
)
{
importCodes
.
push
(
`import
${
define
}
from '
${
source
}
'`
)
assignCodes
.
push
(
`
${
globalObject
}
.
${
define
}
=
${
define
}
`
)
}
else
if
(
Array
.
isArray
(
define
))
{
importCodes
.
push
(
`import {
${
define
.
join
(
'
,
'
)}
} from '
${
source
}
'`
)
define
.
forEach
((
d
)
=>
{
assignCodes
.
push
(
`
${
globalObject
}
.
${
d
}
=
${
d
}
`
)
})
}
else
{
const
keys
=
Object
.
keys
(
define
)
const
specifiers
=
[]
keys
.
forEach
((
d
)
=>
{
if
(
d
!==
define
[
d
])
{
specifiers
.
push
(
`
${
define
[
d
]}
as
${
d
}
`
)
}
else
{
specifiers
.
push
(
d
)
}
assignCodes
.
push
(
`
${
globalObject
}
.
${
d
}
=
${
d
}
`
)
})
importCodes
.
push
(
`import {
${
specifiers
.
join
(
'
,
'
)}
} from '
${
source
}
'`
)
}
return
[
importCodes
,
assignCodes
]
}
packages/vue-cli-plugin-uni/lib/app-plus/index.js
浏览文件 @
e42ead51
...
...
@@ -5,7 +5,8 @@ const {
getMainEntry
,
getPlatformStat
,
getPlatformPush
,
getPlatformUniCloud
getPlatformUniCloud
,
uniModulesLoader
}
=
require
(
'
@dcloudio/uni-cli-shared
'
)
const
vueLoader
=
require
(
'
@dcloudio/uni-cli-shared/lib/vue-loader
'
)
...
...
@@ -65,7 +66,7 @@ const v3 = {
const
pushCode
=
getPlatformPush
()
const
uniCloudCode
=
getPlatformUniCloud
()
const
beforeCode
=
'
import
\'
uni-pages
\'
;
'
const
beforeCode
=
`import 'uni-pages';import '
${
uniModulesLoader
}
!';`
if
(
!
webpackConfig
.
optimization
)
{
webpackConfig
.
optimization
=
{}
}
...
...
@@ -163,7 +164,7 @@ const v3 = {
compiler
:
vueLoader
.
compiler
,
before
:
[
beforeCode
+
require
(
'
../util
'
).
getAutomatorCode
()
+
statCode
+
pushCode
+
uniCloudCode
+
getGlobalUsingComponentsCode
()
getGlobalUsingComponentsCode
()
]
}
}]
...
...
@@ -278,4 +279,4 @@ if (process.env.UNI_USING_V3) {
module
.
exports
=
v3
}
else
{
module
.
exports
=
require
(
'
../mp
'
)
}
}
packages/vue-cli-plugin-uni/lib/h5/index.js
浏览文件 @
e42ead51
...
...
@@ -7,7 +7,8 @@ const {
getH5Options
,
getPlatformStat
,
getPlatformPush
,
getPlatformUniCloud
getPlatformUniCloud
,
uniModulesLoader
}
=
require
(
'
@dcloudio/uni-cli-shared
'
)
const
{
...
...
@@ -103,7 +104,7 @@ module.exports = {
}
catch
(
e
)
{}
const
beforeCode
=
(
useBuiltIns
===
'
entry
'
?
'
import
\'
@babel/polyfill
\'
;
'
:
''
)
+
`import 'uni-pages';import 'uni-
${
process
.
env
.
UNI_PLATFORM
}
';`
`import 'uni-pages';import 'uni-
${
process
.
env
.
UNI_PLATFORM
}
';
import '
${
uniModulesLoader
}
!';
`
return
{
resolve
:
{
...
...
@@ -194,4 +195,4 @@ module.exports = {
require
(
'
./cssnano-options
'
)(
webpackConfig
)
}
}
}
}
packages/vue-cli-plugin-uni/lib/mp/index.js
浏览文件 @
e42ead51
...
...
@@ -9,7 +9,8 @@ const {
getPlatformCssnano
,
getPlatformStat
,
getPlatformPush
,
getPlatformUniCloud
getPlatformUniCloud
,
uniModulesLoader
}
=
require
(
'
@dcloudio/uni-cli-shared
'
)
const
WebpackUniAppPlugin
=
require
(
'
../../packages/webpack-uni-app-loader/plugin/index
'
)
...
...
@@ -181,7 +182,7 @@ module.exports = {
const
pushCode
=
getPlatformPush
()
const
uniCloudCode
=
getPlatformUniCloud
()
let
beforeCode
=
'
import
\'
uni-pages
\'
;
'
let
beforeCode
=
`import 'uni-pages';import '
${
uniModulesLoader
}
!';`
const
plugins
=
[
new
WebpackUniAppPlugin
(),
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录