docusaurus 简明教程
初始化
环境配置
安装Git
安装Node.js
$ brew install node $ node -v v8.5.0
创建一个GitHub项目:
例如 repository 名为
docusaurus-tutorial
,不要加.gitignore
与license在终端:
cd /Users/NAME/doc_projects # macOS example git clone git@github.com:USERNAME/docusaurus-tutorial.git # SSH # or git clone https://github.com/USERNAME/docusaurus-tutorial.git # HTTPS
安装
Docusaurus 初始化
命令npm install --global docusaurus-init
创建一个站点
$ cd docusaurus-tutorial
$ docusaurus-init # 将创建一些模板,部分文件如下:
├── Dockerfile
├── docker-compose.yml
├── docs
│ ├── doc1.md
│ ├── doc2.md
│ ├── doc3.md
│ ├── exampledoc4.md
│ └── exampledoc5.md
└── website
├── README.md
├── blog
│ ├── 2016-03-11-blog-post.md
│ ├── 2017-04-10-blog-post-two.md
│ ├── 2017-09-25-testing-rss.md
│ ├── 2017-09-26-adding-rss.md
│ └── 2017-10-24-new-version-1.0.0.md
├── sidebars.json
├── siteConfig.js
$ cd website && npm start # 将会在浏览器打开 http://localhost:3000
创建一个网页
创建一个常规的页面:
- 进入
website/pages/en
文件夹,保存下面内容到hello-world.js
:
const React = require('react');
const CompLibrary = require('../../core/CompLibrary.js');
const Container = CompLibrary.Container;
const GridBlock = CompLibrary.GridBlock;
function HelloWorld(props) {
return (
<div className="docMainWrapper wrapper">
<Container className="mainContainer documentContainer postContainer">
<h1>Hello World!</h1>
<p>This is my first page!</p>
</Container>
</div>
);
}
module.exports = HelloWorld;
- 然后到 http://localhost:3000/hello-world 查看内容
创建一个文档页面
进入
docs
文件夹(与website文件夹在同一级),并创建doc9.md
文件。在
doc9.md
中放入下面内容:--- id: doc9 title: This is Doc 9 --- I can write content using [GitHub-flavored Markdown syntax](https://github.github.com/gfm/). ## Markdown Syntax **Bold** _italic_ `code` [Links](#url) > Donec sit amet nisl. Aliquam semper ipsum sit amet velit. Suspendisse > id sem consectetuer libero luctus adipiscing. * Hey * Ho * Let's Go
修改
sidebars.json
将markdown文件显示出来:打开website/sidebars.json
,并添加doc9
.ID
要与doc9.md
的ID相同{ "docs": { "Docusaurus": [ "doc1", + "doc9" ], "First Category": ["doc2"], "Second Category": ["doc3"] }, "docs-other": { "First Category": ["doc4", "doc5"] } }
cmd
+C
关闭启动并npm start
重启http://localhost:3000/docs/doc9 将能显示该markdown页面。
发布站点
编辑
docusaurus-tutorial/website/siteConfig.js
修改以下内容:const siteConfig = { ... url: 'https://USERNAME.github.io', // Replace USERNAME with your GitHub username. baseUrl: '/docusaurus-tutorial/', // The name of your GitHub project. projectName: 'docusaurus-tutorial', // The name of your GitHub project. Same as above. organizationName: 'USERNAME' // Your GitHub username. ... }
在终端
cmd+C
在
website
文件夹,运行npm run build
. 该命令会生成HTML静态文件到docusaurus-tutorial/website/build
文件夹。用自己的用户名替换
USERNAME
并运行下面命令:
GIT_USER=USERNAME CURRENT_BRANCH=master USE_SSH=true npm run publish-gh-pages # SSH
# or
GIT_USER=USERNAME CURRENT_BRANCH=master npm run publish-gh-pages # HTTPS
HTML会放到https://github.com/USERNAME/docusaurus-tutorial
添加版本
杀手级功能--版本控制。
发布一个版本:
假设你对当前版本满意,并想将其冻结为V1.0.0
版本,cd website
:
npm run examples versions
That command generates a versions.js
file, which will be used to list down all the versions of docs in the project.
Next, you run a command with the version you want to create, like 1.0.0
.
npm run version 1.0.0