用于配置自定义页面入口。
对于大部分场景,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.tsx
index -> ./src/home/index.ts