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