# 目录结构
MdPress 遵循 “约定优于配置” 的原则,推荐的目录结构如下:
::: file
.
├── docs
│ ├── .mdpress (可选的)
│ │ ├── components (可选的)
│ │ ├── theme (可选的)
│ │ │ └── Layout.js
│ │ ├── public (可选的)
│ │ ├── styles (可选的)
│ │ │ ├── index.styl
│ │ │ └── palette.styl
│ │ ├── templates (可选的, 谨慎配置)
│ │ │ ├── dev.html
│ │ │ └── ssr.html
│ │ ├── config.js (可选的)
│ │ └── enhanceApp.js (可选的)
│ │
│ ├── README.md
│ ├── guide
│ │ └── README.md
│ └── config.md
│
└── package.json
:::
::: warning 注意 请留意目录名的大写。 :::
docs/.mdpress: 用于存放全局的配置、组件、静态资源等。docs/.mdpress/components: 该目录中的 React 组件将会被自动注册为全局组件。docs/.mdpress/theme: 用于存放本地主题。docs/.mdpress/styles: 用于存放样式相关的文件。docs/.mdpress/styles/index.styl: 将会被自动应用的全局样式文件,会生成在最终的 CSS 文件结尾,具有比默认样式更高的优先级。docs/.mdpress/styles/palette.styl: 用于重写默认颜色常量,或者设置新的 stylus 颜色常量。docs/.mdpress/public: 静态资源目录。docs/.mdpress/templates: 存储 HTML 模板文件。docs/.mdpress/templates/dev.html: 用于开发环境的 HTML 模板文件。docs/.mdpress/templates/ssr.html: 构建时基于 React SSR 的 HTML 模板文件。docs/.mdpress/config.js: 配置文件的入口文件,也可以是YML或toml。docs/.mdpress/enhanceApp.js: 客户端应用的增强。
::: warning 注意
当你想要去自定义 templates/ssr.html 或 templates/dev.html 时,最好基于 默认的模板文件 来修改,否则可能会导致构建出错。
:::
同时阅读:
# 默认的页面路由
此处我们把 docs 目录作为 targetDir (参考 命令行接口),下面所有的“文件的相对路径”都是相对于 docs 目录的。在项目根目录下的 package.json 中添加 scripts :
{
"scripts": {
"dev": "mdpres dev docs",
"build": "mdpres build docs"
}
}
对于上述的目录结构,默认页面路由地址如下:
| 文件的相对路径 | 页面路由地址 |
|---|---|
/README.md |
/ |
/guide/README.md |
/guide/ |
/config.md |
/config.html |