1
0
mirror of synced 2026-04-05 16:08:37 +08:00

feat(cli): 添加dynamicImport配置参数,用于设置是否使用import()来加载组件

re #366
This commit is contained in:
roymondchen
2022-09-22 15:21:35 +08:00
committed by jia000
parent cda0c41ad4
commit c817ad6bb6
3 changed files with 25 additions and 6 deletions

View File

@@ -5,25 +5,41 @@ import { EntryType } from '../types';
export const prepareEntryFile = (app: App) => {
const { componentMap = {}, pluginMap = {}, configMap = {}, valueMap = {}, eventMap = {} } = app.moduleMainFilePath;
const { componentFileAffix } = app.options;
const { componentFileAffix, dynamicImport } = app.options;
app.writeTemp('comp-entry.ts', generateContent(EntryType.COMPONENT, componentMap, componentFileAffix));
app.writeTemp(
'async-comp-entry.ts',
generateContent(EntryType.COMPONENT, componentMap, componentFileAffix, dynamicImport),
);
app.writeTemp('plugin-entry.ts', generateContent(EntryType.PLUGIN, pluginMap));
app.writeTemp('config-entry.ts', generateContent(EntryType.CONFIG, configMap));
app.writeTemp('value-entry.ts', generateContent(EntryType.VALUE, valueMap));
app.writeTemp('event-entry.ts', generateContent(EntryType.EVENT, eventMap));
};
const generateContent = (type: EntryType, map: Record<string, string>, componentFileAffix = '') => {
const generateContent = (
type: EntryType,
map: Record<string, string>,
componentFileAffix = '',
dynamicImport = false,
) => {
const list: string[] = [];
const importDeclarations: string[] = [];
Object.entries(map).forEach(([key, packagePath]) => {
const name = makeCamelCase(key);
importDeclarations.push(
`import ${name} from '${packagePath}${packagePath.endsWith(componentFileAffix) ? '' : componentFileAffix}'`,
);
list.push(`'${key}': ${name}`);
if (dynamicImport) {
list.push(
`'${key}': import('${packagePath}${packagePath.endsWith(componentFileAffix) ? '' : componentFileAffix}')`,
);
} else {
importDeclarations.push(
`import ${name} from '${packagePath}${packagePath.endsWith(componentFileAffix) ? '' : componentFileAffix}'`,
);
list.push(`'${key}': ${name}`);
}
});
const exportToken = `${type}s`;