type Entries = Record<
string,
| string
| {
entry: string;
disableMount?: boolean;
}
>;用于配置自定义页面入口。
对于大部分场景,Modern.js 根据目录结构自动生成的入口已经可以满足需求,具体可参考入口。
如果你需要自定义页面入口时,可以通过该选项进行设置。
当 entries 对象的 value 为 string 类型时,表示入口模块的文件路径:
import { defineConfig } from '@modern-js/app-tools';
export default defineConfig({
source: {
entries: {
// 指定一个名称为 'my-entry' 的新入口
'my-entry': './src/home/test/index.ts',
},
// 禁用默认入口扫描
disableDefaultEntries: true,
},
});默认情况下,配置的入口等价于 App.[jt]sx,即指定的入口文件只需要导出应用的根组件。
例如以下目录结构:
.
├── src
│ └── entry
│ ├── chat.tsx
│ └── home.tsx
└── package.json上述目录不符合 Modern.js 的目录结构约定,因此,Modern.js 在分析目录结构时,不会得到任何默认入口。
在不想改变目录结构的情况下(如项目迁移),可以通过 source.entries 自定义入口:
export default defineConfig({
source: {
entries: {
home: './src/entry/home.tsx',
chat: './src/entry/chat.tsx',
},
// 禁用默认入口扫描
disableDefaultEntries: true,
},
});当值为 Object 时,可配置如下属性:
entry:string,入口文件路径。disableMount:boolean = false,关闭 Modern.js 自动生成入口代码的行为。import { defineConfig } from '@modern-js/app-tools';
export default defineConfig({
source: {
entries: {
'my-entry': {
// 入口文件路径
entry: './src/my-page/index.tsx',
disableMount: true,
},
},
// 禁用默认入口扫描
disableDefaultEntries: true,
},
});默认情况下,配置的入口等价于 App.[jt]sx,Modern.js 会自动生成一个入口文件来引用你配置的入口。
如果你希望禁用 Modern.js 自动生成入口文件的逻辑,可以将 disableMount 属性设置为 true。
export default defineConfig({
source: {
entries: {
'my-entry': {
entry: './src/my-page/index.tsx',
disableMount: true,
},
},
// 禁用默认入口扫描
disableDefaultEntries: true,
},
});如果你需要为某个自定义入口启用约定式路由,可以将 entry 设置为目录路径:
import { defineConfig } from '@modern-js/app-tools';
export default defineConfig({
source: {
entries: {
// 启用约定式路由
entry_spa: {
// 约定式路由的入口路径必须设置为目录
entry: './src/about',
},
},
// 禁用默认入口扫描
disableDefaultEntries: true,
},
});在设置 source.entries 后,如果没有设置 disableDefaultEntries: true,Modern.js 会将自定义入口与分析目录结构得到的入口合并。
合并规则为:
例如以下目录结构:
.
├── src
│ ├── chat
│ │ └── App.tsx
│ └── home
│ └── index.ts
└── package.jsonModern.js 会分析 src/ 目录,得到默认入口 chat 和 home。当用户在 modern.config.ts 文件中配置如下时:
import { defineConfig } from '@modern-js/app-tools';
export default defineConfig({
source: {
entries: {
index: './src/home/index.ts',
},
},
};可以看到自定义入口 index 的路径和默认入口 home 的路径一致,在合并的过程中,index 会覆盖掉 home,最终入口如下:
chat -> ./src/chat/App.tsxindex -> ./src/home/index.ts