๐ฆ plugin-content-docs
๋ฌธ์ ๋ง๋ค๊ธฐ ๊ธฐ๋ฅ์ ์ ๊ณตํ๋ ๋ํ์ฌ์ฐ๋ฃจ์ค์ ๊ธฐ๋ณธ ๋ฌธ์ ํ๋ฌ๊ทธ์ธ์ ๋๋ค.
#
์ค์น- npm
- Yarn
npm install --save @docusaurus/plugin-content-docs
yarn add @docusaurus/plugin-content-docs
tip
@docusaurus/preset-classic
์ ์ค์นํ ๊ฒฝ์ฐ์๋ ํ
๋ง๋ฅผ ๋ฐ๋ก ์ค์นํ ํ์๋ ์์ต๋๋ค. ์๋์ ๊ฐ์ด ์ค์ ํ๋ ๋์ classic preset options์์ ์ค์ ํ ์ ์์ต๋๋ค.
#
์ค์ docusaurus.config.js
module.exports = { plugins: [ [ '@docusaurus/plugin-content-docs', { /** * ์ฌ์ดํธ ๋๋ ํฐ๋ฆฌ์ ์๋ ๊ฒฝ๋ก๋ก ํ์ผ ์์คํ
์ ๋ฐ์ดํฐ ๊ฒฝ๋ก๋ฅผ ์ค์ ํฉ๋๋ค. */ path: 'docs', /** * ์ฌ๋ฌ๋ถ์ ์ฌ์ดํธ๋ฅผ ํธ์งํ๊ธฐ ์ํ Base url์ ์ค์ ํฉ๋๋ค. * ๋ํ์ฌ์ฐ๋ฃจ์ค๋ "editUrl + relativeDocPath" ํ์์ผ๋ก ์ค์ ํธ์งํ ์ ์๋ editUrl์ ์ฒ๋ฆฌํฉ๋๋ค. */ editUrl: 'https://github.com/facebook/docusaurus/edit/master/website/', /** * ํ์์ ๋ฐ๋ผ ๊ฐ ๋งํฌ๋ค์ด ํ์ผ์ editUrl์ ์ง์ ์ค์ ํด์ค ์ ์์ต๋๋ค. */ editUrl: function ({ locale, version, versionDocsDirPath, docPath, permalink, }) { return `https://github.com/facebook/docusaurus/edit/master/website/${versionDocsDirPath}/${docPath}`; }, /** * ๋ฒ์ญ๋ ํ์ผ์ ๊น์ ์ปค๋ฐํ๋ ๊ฒฝ์ฐ ์ ์ฉํ ์ค์ ์
๋๋ค. * ๋งํฌ๋ค์ด ํ์ผ์ ํ์งํํ๊ฒ ๋๋ฉด ํธ์ง URL์ ํ์งํ๋์ง ์์ ์๋ณธ ํ์ผ ๋์ * ํ์งํ๋ ํ์ผ์ ๊ฐ๋ฆฌํค๊ฒ ๋ฉ๋๋ค. * ์ฐธ๊ณ : editUrl์ด ํจ์์ธ ๊ฒฝ์ฐ์ ํด๋น ์ต์
์ ๋ฌด์๋ฉ๋๋ค. */ editLocalizedFiles: false, /** * ์ด์ ๋ฒ์ ์ ๋ํ ์ฌ์ฉ์์ ํ ๋ฆฌํ์คํธ ์์ฒญ์ ๋ง์ ๊ฒฝ์ฐ ์ ์ฉํฉ๋๋ค. * ๋ฌธ์ ๋ฒ์ ์ด ์ฌ๋ผ๊ฐ ๊ฒฝ์ฐ ํธ์งํ ์ ์๋ url์ ์ด์ ๋ฒ์ ๋ฌธ์ ๋์ * ํ์ฌ ๋ฒ์ ๋ฌธ์๋ก ์ฐ๊ฒฐ๋๋๋ก ํฉ๋๋ค. * ์ฐธ๊ณ : editUrl์ด ํจ์์ธ ๊ฒฝ์ฐ์ ํด๋น ์ต์
์ ๋ฌด์๋ฉ๋๋ค. */ editCurrentVersion: false, /** * ์ฌ๋ฌ๋ถ์ ์ฌ์ดํธ ๋ฌธ์ ๋๋ ํฐ๋ฆฌ์ ๋ํ URL ๊ฒฝ๋ก๋ฅผ ์ค์ ํฉ๋๋ค. * *์ ๋* URL ๋์ ์ฌ๋์๋ฅผ ๋ถ์ด์ง ๋ง์ธ์. * ์ฐธ๊ณ : base ๊ฒฝ๋ก ์์ด ๋ฐฐํฌ๋๋ ๋ฌธ์๋ `/`์ ์ค์ ํ ์๋ ์์ต๋๋ค. */ routeBasePath: 'docs', include: ['**/*.md', '**/*.mdx'], // Extensions to include. /** * ๋งํฌ๋ค์ด ํ์ด์ง ๋ชฉ๋ก์ ๋ณด์ฌ์ฃผ๋ ์ฌ์ด๋๋ฐ ๊ฒฝ๋ก๋ฅผ ์ค์ ํฉ๋๋ค. */ sidebarPath: 'sidebars.js', /** * "autogenerated" ํ์
์ ์ฌ์ด๋๋ฐ ์์ดํ
์ ์ค์ ์ฌ์ด๋๋ฐ ์์ดํ
(๋ฌธ์, ์นดํ
๊ณ ๋ฆฌ, ๋งํฌ ๋ฑ)์ผ๋ก * ๋ฐ๊พธ๊ธฐ ์ํด ์ฌ์ฉํ๋ ํจ์์
๋๋ค. */ sidebarItemsGenerator: async function ({ defaultSidebarItemsGenerator, // ๋ํ์ฌ์ฐ๋ฃจ์ค์์ ์ฌ์ด๋๋ฐ๋ฅผ ๋ง๋๋ ๊ธฐ๋ณธ ๋ก์ง์ ์ฌ์ฌ์ฉํ๊ฑฐ๋ ํฅ์์ํฌ ๋ ์ ์ฉํฉ๋๋ค. numberPrefixParser, // ํ๋ฌ๊ทธ์ธ์ ์ํ numberPrefixParser๋ฅผ ์ค์ ํฉ๋๋ค. item, // "autogenerated" ํ์
์ ์ฌ์ด๋๋ฐ ์์ดํ
์
๋๋ค. version, // ํ์ฌ ๋ฒ์ ์ ์ค์ ํฉ๋๋ค. docs, // ํด๋น ๋ฒ์ ์ ๋ชจ๋ ๋ฌธ์(ํํฐ๋งํ์ง ์์)๋ฅผ ์ค์ ํฉ๋๋ค. }) { // ์ฌ์ฉ์ ์ง์ ์ฌ์ด๋๋ฐ ์ฌ๋ผ์ด์ค๋ฅผ ๋ง๋ค๊ธฐ ์ํด ์ฃผ์ด์ง ๋ฐ์ดํฐ๋ฅผ ์ฌ์ฉํฉ๋๋ค. return [ {type: 'doc', id: 'intro'}, { type: 'category', label: 'Tutorials', items: [ {type: 'doc', id: 'tutorial1'}, {type: 'doc', id: 'tutorial2'}, ], }, ]; }, /** * ๋ฌธ์ ํ๋ฌ๊ทธ์ธ์ "01-My Folder/02.My Doc.md"๊ฐ์ ์ซ์ ํ์์ ์ ๋์ฌ๋ฅผ ์ง์ํฉ๋๋ค. * ๋ฒํธ ์ ๋์ฌ๋ ์๋์ผ๋ก ์ถ์ถ๋์ด ์๋ ์์ฑ๋ ์ฌ์ด๋๋ฐ ์์ดํ
์ ์ ๋ ฌ ์์๋ก ์ฌ์ฉ๋ฉ๋๋ค. * ์ฌ์ฉ์ฑ์ ์ํด ๊ธฐ๋ณธ ๋ฌธ์์ id, ์ด๋ฆ, ์ ๋ชฉ์์ ์ซ์ ์ ๋์ฌ๋ ์๋์ผ๋ก ์ ๊ฑฐ๋ฉ๋๋ค. * ๊ตฌ๋ฌธ ๋ถ์์ ์ํ ๋ก์ง์์ ๋ชจ๋ ์ฌ์ฉ ๋ฐฉ์๊ณผ ํ์ผ๋ช
ํจํด์ ํ์ฉํ๋๋ก ์ค์ ํ ์ ์์ต๋๋ค. * "false"๋ฅผ ์ค์ ํ๋ฉด ์๋ฌด ๋์ ์์ด ๋ฌธ์๋ฅผ ๊ฑด๋๋ฆฌ์ง ์์ ์ํ๋ก ์ ์งํฉ๋๋ค. */ numberPrefixParser: function (filename) { // ์ ์ฌ์ ์ธ ๋ฒํธ ์ ๋์ฌ๋ฅผ ์ถ์ถํ๊ธฐ ์ํ ์ฌ์ฉ์ ์ง์ ๋ก์ง์ ๊ตฌํํฉ๋๋ค. const numberPrefix = findNumberPrefix(filename); // ์ ๋์ฌ๋ฅผ ๋ฐ๊ฒฌํ๋ฉด ์์ ๋ ํ์ผ๋ช
๊ณผ ํจ๊ป ๋ฐํํฉ๋๋ค. if (numberPrefix) { return { numberPrefix, filename: filename.replace(prefix, ''), }; } // ์ ๋์ฌ๊ฐ ๋ณ๊ฒฌ๋์ง ์์ผ๋ฉด return {numberPrefix: undefined, filename}; }, /** * ๋ฌธ์ ํ์ด์ง์์ ์ฌ์ฉํ ํ
๋ง ์ปดํฌ๋ํธ๋ฅผ ์ค์ ํฉ๋๋ค. */ docLayoutComponent: '@theme/DocPage', docItemComponent: '@theme/DocItem', /** * MDX์ ์ ๋ฌํ Remark, Rehype ํ๋ฌ๊ทธ์ธ์ ์ค์ ํฉ๋๋ค. */ remarkPlugins: [ /* require('remark-math') */ ], rehypePlugins: [], /** * ๊ธฐ๋ณธ Remark, Rehype ํ๋ฌ๊ทธ์ธ์ด ์ ์ฉ๋๊ธฐ ์ ์ * MDX์ ์ฌ์ฉ์ ์ง์ Remark, Rehype ํ๋ฌ๊ทธ์ธ์ ์ ๋ฌํ๋๋ก ์ค์ ํฉ๋๋ค. */ beforeDefaultRemarkPlugins: [], beforeDefaultRehypePlugins: [], /** * ๋ง์ง๋ง์ผ๋ก ๋ฌธ์๋ฅผ ์์ ํ ์ฌ์ฉ์๋ฅผ ํ์ํ ์ง ์ฌ๋ถ๋ฅผ ์ค์ ํฉ๋๋ค. */ showLastUpdateAuthor: false, /** * ๋ง์ง๋ง์ผ๋ก ๋ฌธ์๋ฅผ ์์ ํ ์ผ์๋ฅผ ํ์ํ ์ง ์ฌ๋ถ๋ฅผ ์ค์ ํฉ๋๋ค. */ showLastUpdateTime: false, /** * ๊ธฐ๋ณธ์ ์ผ๋ก ๋ฌธ์ ๋ฒ์ ์ ๊ด๋ฆฌํ๋ ์ฌ์ดํธ๋ ๋ฒ์ ๊ด๋ฆฌ ๊ธฐ๋ฅ์ด ํ์ฑํ๋ฉ๋๋ค. * ์๋ ์ต์
์ ๋ช
์์ ์ผ๋ก ๋ฒ์ ๊ด๋ฆฌ ๊ธฐ๋ฅ์ ๋นํ์ฑํํ ์ ์์ต๋๋ค. * "current" ๋ฒ์ (`/docs` ๋๋ ํฐ๋ฆฌ)์๋ง ์ ์ฉ๋ฉ๋๋ค. */ disableVersioning: false, /** * ๋ฌธ์์ "current" ๋ฒ์ (`/docs` ๋๋ ํฐ๋ฆฌ) ํฌํจ ์ฌ๋ถ๋ฅผ ์ค์ ํฉ๋๋ค. * ํ: current ๋ฒ์ ์ด ์์
์ค์ด๊ณ ์์ง ๋ฐฐํฌํ ์ค๋น๊ฐ ๋์ง ์์์ ๋ ๊บผ๋์ต๋๋ค. */ includeCurrentVersion: true, /** * ๋ง์ง๋ง ๋ฒ์ ์ ๋ฒ์ ๊ด๋ฆฌ๋ฅผ ์ ์ฉํ ์ฌ์ดํธ์์ ์ฐ์ ์ ์ผ๋ก ํ์ํ๋ ๋์์
๋๋ค. * ๋ฌธ์ ํ์๋ฐ์์ ๊ธฐ๋ณธ๊ฐ์ผ๋ก ํ์๋๋ ๊ฐ์
๋๋ค. * ๊ธฐ๋ณธ์ ์ผ๋ก ๋ง์ง๋ง ๋ฒ์ ์ versions.json ํ์ผ ๋ด ์ฒซ ํญ๋ชฉ์ ์์นํ ๊ฐ์
๋๋ค. * ๊ธฐ๋ณธ์ ์ผ๋ก ๋ง์ง๋ง ๋ฒ์ ์ "root" (๋ฌธ์ ๊ฒฝ๋ก=/docs/myDoc)์ ์์นํฉ๋๋ค. * ์ฐธ๊ณ : ๋ง์ง๋ง ๋ฒ์ ์ ๊ฒฝ๋ก์ ํ์๋๋ ๊ฐ์ ์ค์ ํ ์ ์์ต๋๋ค. * ํ: 'current'๋ก ๊ฐ์ ์ค์ ํ๋ฉด ๋๋ถ๋ถ ๋ฌธ์ ๊ฐ ์์ต๋๋ค. */ lastVersion: undefined, /** * ๋ํ์ฌ์ฐ๋ฃจ์ค์ ๊ธฐ๋ณธ ์๋ก ์ค์ ํ versions ์ค์ ๊ฐ์ ๋๋ถ๋ถ ํ๋ก์ ํธ์ ์ ํฉํ์ง๋ ์์ต๋๋ค. * ๊ฐ ๋ฒ์ ์ ์์ฑ์ ๋
๋ฆฝ์ ์ผ๋ก ์ฌ์ฉ์๊ฐ ์ ์ํ๊ณ ์ ํ ๋ ์ฌ์ฉํ ์ ์์ต๋๋ค. * - label: ๋ฒ์ ํ์๊ฐ * - path: ๋ฒ์ ์ ๋ผ์ฐํธ ๊ฒฝ๋ก * - banner: ํด๋น ๋ฒ์ ๋ฌธ์ ์๋จ์ ํ์ํ ๋ฐฐ๋: "none" | "unreleased" | "unmaintained" */ versions: { /* Example configuration: current: { label: 'Android SDK v2.0.0 (WIP)', path: 'android-2.0.0', banner: 'none', }, '1.0.0': { label: 'Android SDK v1.0.0', path: 'android-1.0.0', banner: 'unmaintained', }, */ }, /** * ์ฌ์ฉํ ์ ์๋ ๋ฒ์ ์ค ์ผ๋ถ๋ง ํฌํจํ๋ ค๋ ๊ฒฝ์ฐ ์ฌ์ฉํ๋ ์ต์
์
๋๋ค. * ํ: ๊ฐ๋ฐ ๋ฐ ๋ฐฐํฌ ๋ฏธ๋ฆฌ ๋ณด๊ธฐ ์ํ์์๋ ์์ ๋ฐ ๋น๋ ์ฑ๋ฅ์ ํฅ์์ํค๊ธฐ ์ํด 2~3๊ฐ ์ ๋ ๋ฒ์ ๋ง ์ฌ์ฉํ๋ ๊ฒ์ด ์ข์ต๋๋ค. */ onlyIncludeVersions: undefined, // ์: ["current", "1.0.0", "2.0.0"] }, ], ],};
#
๋งํฌ๋ค์ด ํ๋ฐํธ ๋งคํฐ๋งํฌ๋ค์ด ๋ฌธ์์์๋ ---
๋ก ๊ฐ์ผ ๋งํฌ๋ค์ด ํ๋ฐํธ ๋งคํฐ ์์ญ์์ ์๋์ ๊ฐ์ ๋ฉํ๋ฐ์ดํฐ ํ๋๋ฅผ ์ฌ์ฉํ ์ ์์ต๋๋ค.
id
: ์ ์ผํ ๋ฌธ์ id์ ๋๋ค. ๊ธฐ๋ณธ๊ฐ: ํ์ผ ๊ฒฝ๋ก(ํ์ฅ์๋ ์ ์ธํ๊ณ ๋๋ ํฐ๋ฆฌ๋ ํฌํจ)title
: ๋ฌธ์ ์ ๋ชฉ์ ๋๋ค. ํ์ด์ง ๋ฉํ๋ฐ์ดํฐ๋ก ์ฌ์ฉํ๋ฉฐ ์ฌ๋ฌ ์์น(์ฌ์ด๋๋ฐ, ๋ค์/์ด์ ๋ฒํผ ๋ฑ)์์ ๋์ฒด๊ฐ์ผ๋ก ์ฌ์ฉ๋ฉ๋๋ค. ๋งํฌ๋ค์ด ์ ๋ชฉ์ด ์๋ ๊ฒฝ์ฐ ๋ฌธ์ ์๋จ์ ์๋์ผ๋ก ์ถ๊ฐ๋ฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ: ๋งํฌ๋ค์ด ์ ๋ชฉ ๋๋ ๋ฌธ์id
hide_title
: ๋ฌธ์ ์๋จ์์ ์ ๋ชฉ์ ์จ๊ธธ์ง ์ฌ๋ถ๋ฅผ ์ค์ ํฉ๋๋ค. ํ๋ฐํธ ๋งคํฐ ์์ญ์์ ์ค์ ํ ์ ๋ชฉ๋ง ๊ฐ์ถฅ๋๋ค. ๋งํฌ๋ค์ด ๋ฌธ์ ๋ด์ ์ง์ ๋ ํ์ดํ์๋ ์ํฅ์ ์ฃผ์ง ์์ต๋๋ค. ๊ธฐ๋ณธ๊ฐ:false
hide_table_of_contents
: ์ค๋ฅธ์ชฝ์ ํ์๋๋ ๋ชฉ์ฐจ ์จ๊น ์ฌ๋ถ๋ฅผ ์ค์ ํฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ:false
sidebar_label
: ๋ฌธ์ ๋ด์์ ๋ฌธ์์ ์ฌ์ด๋๋ฐ์ ํ์ํ ํ ์คํธ๋ฅผ ์ค์ ํฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ:title
sidebar_position
:autogenerated
์ฌ์ด๋๋ฐ ์์ดํ ์ ์ฌ์ฉํ๋ ๊ฒฝ์ฐ ๋ง๋ค์ด์ง ์ฌ์ด๋๋ฐ ์ฌ๋ผ์ด์ค ๋ด์์ ๋ฌธ์ ์์น๋ฅผ ์กฐ์ ํ ์ ์์ต๋๋ค. Int ๋๋ Float ๊ฐ์ ์ค์ ํ ์ ์์ต๋๋ค.pagination_label
: ๋ฌธ์ ๋ด์์ ๋ฌธ์์ ๋ค์/์ด์ ๋ฒํผ์ ํ์ํ ํ ์คํธ๋ฅผ ์ค์ ํฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ:sidebar_label
๋๋title
parse_number_prefixes
: ๋ฌธ์์ ๋ฒํธ ์ ๋์ฌ(001 - My Doc.md
,2. MyDoc.md
...)๊ฐ ์๋ ๊ฒฝ์ฐnumberPrefixParser
ํ๋ฌ๊ทธ์ธ์์ ์๋์ผ๋ก ๊ตฌ๋ฌธ์ ๋ถ์ํ๊ณ ์ถ์ถํดsidebar_position
์ผ๋ก ๋ฒํธ ์ ๋์ฌ๋ฅผ ์ฌ์ฉํฉ๋๋ค.parse_number_prefixes: false
๋ก ์ค์ ํ๋ฉด ๋ฌธ์์์ ๋ฒํธ ์ ๋์ฌ ๊ตฌ๋ฌธ ๋ถ์์ ์ฌ์ฉํ์ง ์์ต๋๋ค. ๊ธฐ๋ณธ๊ฐ:parse_number_prefixes
ํ๋ฌ๊ทธ์ธ ์ต์ custom_edit_url
: ๋ฌธ์๋ฅผ ํธ์งํ ์ ์๋ URL์ ์ค์ ํฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ:editUrl
ํ๋ฌ๊ทธ์ธ ์ต์ ์ ์ฌ์ฉํด ๊ณ์ฐ๋ ๊ฐkeywords
: ๊ฒ์ ์์ง์์ ํ์ํ ๋ฌธ์ ํ์ด์ง์ ํค์๋ ๋ฉํ ํ๊ทธ๋ฅผ ์ค์ ํฉ๋๋ค.description
: ๋ฌธ์์ ์ค๋ช ์ ๊ฒ์์์ง์์ ์ฌ์ฉํ ์ ์๊ฒ<head>
ํ๊ทธ ์์<meta name="description" content="..."/>
์<meta property="og:description" content="..."/>
๋ก ์ฒ๋ฆฌ๋ฉ๋๋ค. ๊ธฐ๋ณธ๊ฐ: ๋งํฌ๋ค์ด ์ฝํ ์ธ ์ฒซ ๋ฒ์งธ ์คimage
: ๊ฒ์๊ธ์ ๋ํ ๋งํฌ๋ฅผ ํ์ํ ๋ ๋ณด์ฌ์ง๋ ์ปค๋ฒ ๋๋ ์ฌ๋ค์ผ ์ด๋ฏธ์ง๋ฅผ ์ค์ ํฉ๋๋ค.slug
: ๋ฌธ์ url์ ๋ณ๊ฒฝํ ์ ์๋๋ก ํ์ฉํฉ๋๋ค(/<routeBasePath>/<slug>
). ์ฌ๋ฌ ํจํด์ ์ค์ ํ ์๋ ์์ต๋๋ค:slug: my-doc
,slug: /my/path/myDoc
,slug: /
.
์๋ฅผ ๋ค๋ฉด ์๋์ ๊ฐ์ด ์ค์ ํฉ๋๋ค.
---id: doc-markdowntitle: Docs Markdown Featureshide_title: falsehide_table_of_contents: falsesidebar_label: Markdownsidebar_position: 3pagination_label: Markdown featurescustom_edit_url: https://github.com/facebook/docusaurus/edit/master/docs/api-doc-markdown.mddescription: How do I find you when I cannot solve this problemkeywords: - docs - docusaurusimage: https://i.imgur.com/mErPwqL.pngslug: /myDoc---# Markdown Features
My Document Markdown content
#
i18ni18n ์๊ฐ ๋ฌธ์๋ฅผ ๋จผ์ ํ์ธํด์ฃผ์ธ์.
#
๋ฒ์ญ ํ์ผ ์์น- ๊ธฐ๋ณธ ๊ฒฝ๋ก:
website/i18n/<locale>/docusaurus-plugin-content-docs
- ๋ฉํฐ ์ธ์คํด์ค ๊ฒฝ๋ก:
website/i18n/<locale>/docusaurus-plugin-content-docs-<pluginId>
- JSON ํ์ผ:
docusaurus write-translations
๋ช ๋ น ์คํ ํ ๋ง๋ค์ด์ง ํ์ผ - ๋งํฌ๋ค์ด ํ์ผ:
website/i18n/<locale>/docusaurus-plugin-content-docs/<version>
#
ํ์ผ ์์คํ ๊ตฌ์กฐ ์website/i18n/<locale>/docusaurus-plugin-content-docsโโ # translations for website/docsโโโ currentโย ย โโโ apiโย ย โย ย โโโ config.mdโย ย โโโ getting-started.mdโโโ current.jsonโโ # translations for website/versioned_docs/version-1.0.0โโโ version-1.0.0โย ย โโโ apiโย ย โย ย โโโ config.mdโย ย โโโ getting-started.mdโโโ version-1.0.0.json