테마 설정
이 설정은 모든 메인 테마에 적용됩니다.
공통
컬러 모드
클래식 테마는 메뉴바에서 밝은 모드와 어두운 모드를 선택할 수 있는 기능을 기본으로 지원합니다.
colorMode
오브젝트 내에서 사용자 지정 컬러 모드를 설정할 수 있습니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
defaultMode | 'light' | 'dark' | 'light' | 사용자가 사이트를 처음 방문할 때 컬러 모드입니다. |
disableSwitch | boolean | false | 메뉴바에서 스위치를 숨깁니다. 하나의 컬러 모드만 지원하기 원하는 경우 유용합니다. |
respectPrefersColorScheme | boolean | false | 직접 설정한 defaultMode 대신 사용자 시스템 기본 설정을 사용해 prefers-color-scheme 미디어 쿼리를 사용할지 여부 |
설정 예시:
export default {
themeConfig: {
colorMode: {
defaultMode: 'light',
disableSwitch: false,
respectPrefersColorScheme: false,
},
},
};
respectPrefersColorScheme: true
로 설정한 경우 defaultMode
설정값은 사용자 시스템 환경 설정에 따라 재정의됩니다.
하나의 색상 모드만 지원하려면 사용자 시스템 환경 설정에 영향을 받지 않게 해야 합니다.
메타 정보 이미지
og:image
나 twitter:image
처럼 메타 태그에서 사용할 기본 이미지를 설정합니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
image | string | undefined | 사이트의 메타 이미지 URL입니다. 사이트 "정적" 디렉터리에 상대 경로로 설정합니다. SVG 파일은 설정할 수 없습니다. 외부 URL은 사용할 수 있습니다. |
설정 예시:
export default {
themeConfig: {
image: 'img/docusaurus.png',
},
};
메타데이터
HTML 메타 데이터를 추가하거나 (기존 항목을 재정의할 수 있습니다).
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
metadata | Metadata[] | [] | 모든 필드는 <meta /> 태그로 직접 전달됩니다. 사용할 수 있는 필드는 id , name , property , content , itemprop 등이 있습니다. |
설정 예시:
export default {
themeConfig: {
metadata: [{name: 'twitter:card', content: 'summary'}],
},
};
알림표시줄
웹 사이트에서 공지할 내용이 생길 수 있습니다. 그런 경우 알림표시줄을 추가할 수 있습니다. 메뉴바 위에 고정되지 않고 선택적으로 사용자가 닫을 수 있는 패널이 표시됩니다. 모든 설정은 announcementBar
오브젝트에서 처리합니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
id | string | 'announcement-bar' | 메시지를 식별하는 모든 값입니다. |
content | string | '' | 알리고자 하는 텍스트 콘텐츠입니다. HTML을 삽입할 수 있습니다. |
backgroundColor | string | '#fff' | 알림표시줄 영역 배경색입니다. |
textColor | string | '#000' | 알림메시지 텍스트 색상입니다. |
isCloseable | boolean | true | 알림메시지를 'x' 버튼으로 닫을 수 있는지 여부 |
설정 예시:
export default {
themeConfig: {
announcementBar: {
id: 'support_us',
content:
'We are looking to revamp our docs, please fill <a target="_blank" rel="noopener noreferrer" href="#">this survey</a>',
backgroundColor: '#fafbfc',
textColor: '#091E42',
isCloseable: false,
},
},
};
플러그인
Our main themes offer additional theme configuration options for Docusaurus core content plugins.
문서
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
versionPersistence | 'localStorage' | 'none' | undefined | Defines the browser persistence of the preferred docs version. |
sidebar.hideable | boolean | false | Show a hide button at the bottom of the sidebar. |
sidebar.autoCollapseCategories | boolean | false | Automatically collapse all sibling categories of the one you navigate to. |
설정 예시:
export default {
themeConfig: {
docs: {
versionPersistence: 'localStorage',
sidebar: {
hideable: false,
autoCollapseCategories: false,
},
},
},
};
블로그
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
sidebar.groupByYear | boolean | true | Group sidebar blog posts by years. |
설정 예시:
export default {
themeConfig: {
blog: {
sidebar: {
groupByYear: true,
},
},
},
};
메뉴바
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
title | string | undefined | 메뉴바 제목 |
logo | 아래를 참조하세요. | undefined | 로고 오브젝트 사용자 지정 |
items | NavbarItem[] | [] | 메뉴바 아이템 목록입니다. 상세한 내용은 아래 내용을 참고하세요. |
hideOnScroll | boolean | false | 사용자가 아래로 스크롤할 때 메뉴바를 숨길지 여부입니다. |
style | 'primary' | 'dark' | theme와 같음 | 어두운/밝은 테마 설정을 무시하고 메뉴바 스타일을 설정합니다. |
메뉴바 로고
로고는 static 디렉터리에 가져다 놓을 수 있습니다. 로고 URL은 기본적으로 여러분의 사이트 기본 URL이 설정됩니다. 로고 URL을 따로 설정할 수는 있지만 외부 링크인 경우에는 새로운 탭에서 열리게 됩니다. 또한 로고 링크의 target 속성값을 재정의할 수 있습니다. 메인 웹 사이트의 하위 디렉터리에서 문서 웹 사이트를 서비스하는 경우에 유용한 기능입니다. 이런 경우 메인 웹 사이트를 새로운 탭에서 열어주는 로고 링크가 필요하지 않을 수도 있습니다.
어두운 모드 지원을 위해 모드마다 다른 로고를 설정할 수도 있습니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
alt | string | undefined | 로고 이미지의 Alt 태그입니다. |
src | string | 필수 | 로고 이미지의 URL입니다. 기본적으로 기본 URL이 추가됩니다. |
srcDark | string | logo.src | 어두운 모드에서 사용할 대체 이미지 URL입니다. |
href | string | siteConfig.baseUrl | 로고 클릭 시 이동할 링크입니다. |
width | string | number | undefined | width 속성을 설정합니다. |
height | string | number | undefined | height 속성을 설정합니다. |
target | string | href 값에 따라 처리합니다(외부 링크는 새 탭으로 열리고 다른 모든 링크는 현재 탭에서 열립니다). | 링크의 target 속성입니다. 링크가 새 탭에서 열릴지 현재 탭에서 열릴지 여부를 설정합니다. |
className | string | undefined | 이미지에 적용된 CSS 클래스 |
style | object | undefined | CSS 인라인 스타일 오브젝트. 리액트/JSX에서는 카멜표기법을 선호합니다. |
설정 예시:
export default {
themeConfig: {
navbar: {
title: 'Site Title',
logo: {
alt: 'Site Logo',
src: 'img/logo.svg',
srcDark: 'img/logo_dark.svg',
href: 'https://docusaurus.io/',
target: '_self',
width: 32,
height: 32,
className: 'custom-navbar-logo-class',
style: {border: 'solid red'},
},
},
},
};
메뉴바 아이템
themeConfig.navbar.items
설정에서 메뉴바에 아이템을 추가할 수 있습니다.
export default {
themeConfig: {
navbar: {
items: [
{
type: 'doc',
position: 'left',
docId: 'introduction',
label: 'Docs',
},
{to: 'blog', label: 'Blog', position: 'left'},
{
type: 'docsVersionDropdown',
position: 'right',
},
{
type: 'localeDropdown',
position: 'right',
},
{
href: 'https://github.com/facebook/docusaurus',
position: 'right',
className: 'header-github-link',
'aria-label': 'GitHub repository',
},
],
},
},
};
아이템은 type
필드에 따라 다르게 동작할 수 있습니다. 사용할 수 있는 모든 유형의 메뉴바 아이템을 아래에 소개합니다.
메뉴바 링크
기본적으로 메뉴바 아이템은 일반 링크(내부 또는 외부)입니다.
리액트 라우터는 자동으로 링크에 대해서 활성 링크 스타일을 적용합니다. 하지만 필요에 따라 activeBasePath
를 사용할 수 있습니다. 여러 다른 경로의 링크를 활성화해야 하는 경우(예를 들면 같은 사이드바 아래 여러 문서 디렉터리가 포함된 경우) activeBaseRegex
를 사용할 수 있습니다. activeBaseRegex
는 activeBasePath
보다 유연한 대안이며 우선적으로 적용됩니다. 도큐사우루스에서는 현재 URL에 정규식으로 적용해 구문 분석을 처리합니다.
외부 링크는 자동으로 target="_blank" rel="noopener noreferrer"
코드가 적용됩니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'default' | 선택사항 | 항목 유형을 링크로 설정합니다. |
label | string | 필수 | 아이템을 표시하는 이름입니다. |
html | string | 선택사항 | label 과 같지만 텍스트 콘텐츠 대신 HTML을 렌더링합니다. |
to | string | 필수 | 웹 사이트 내에서 탐색을 위해 사용하는 클라이언트 라우팅입니다. 해당 값 앞에 baseUrl이 자동으로 추가됩니다. |
href | string | 필수 | 웹 사이트 외부 탐색을 위해 사용하는 전체 페이지 탐색입니다. to 또는 href 중 하나만 사용해야 합니다. |
prependBaseUrlToHref | boolean | false | baseUrl을 href 값 앞에 추가합니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
activeBasePath | string | to / href | 해당 경로로 시작하는 모든 경로에 활성화된 클래스 스타일을 적용합니다. 일반적인 경우는 필요하지 않습니다. |
activeBaseRegex | string | undefined | 필요한 경우 activeBasePath 를 대체해 사용할 수 있습니다. |
className | string | '' | 사용자 지정 CSS 클래스(특정 아이템 스타일 처리) |
위에 설명한 필드 외에 HTML 링크에 적용할 수 있는 다른 속성을 사용할 수 있습니다.
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
to: 'docs/introduction',
// Only one of "to" or "href" should be used
// href: 'https://www.facebook.com',
label: 'Introduction',
// Only one of "label" or "html" should be used
// html: '<b>Introduction</b>'
position: 'left',
activeBaseRegex: 'docs/(next|v8)',
target: '_blank',
},
],
},
},
};
메뉴바 드롭다운
dropdown
유형의 메뉴바 아이템은 추가적으로 items
필드를 내부 배열 형태로 가질 수 있습니다.
메뉴바 드롭다운 아이템은 아래와 같이 "링크 기능을 지원하는" 아이템 유형만 허용합니다.
드롭다운 기본 아이템도 클릭할 수 있는 링크이므로 해당 아이템은 일반적인 메뉴바 링크의 모든 속성을 가질 수 있습니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'dropdown' | 선택사항 | 항목 유형을 드롭다운으로 설정합니다. |
label | string | 필수 | 아이템을 표시하는 이름입니다. |
items | LinkLikeItem[] | 필수 | 드롭다운에 포함될 아이템입니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'dropdown',
label: 'Community',
position: 'left',
items: [
{
label: 'Facebook',
href: 'https://www.facebook.com',
},
{
type: 'doc',
label: 'Social',
docId: 'social',
},
// ... more items
],
},
],
},
},
};
메뉴바 문서 링크
특정 문서에 대한 링크를 만들고 싶은 경우 특정 메뉴바 아이템 타입을 설정하면 docId
를 기준으로 문서 링크를 만듭니다. 같은 사이드바 문서를 탐색하고 있다면 navbar__link--active
클래스를 얻게 됩니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'doc' | 필수 | 항목 유형을 문서 링크로 설정합니다. |
docId | string | 필수 | 아이템에서 링크로 연결되는 문서의 ID입니다. |
label | string | docId | 아이템을 표시하는 이름입니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
docsPluginId | string | 'default' | 문서가 속한 문서 플러그인 ID입니다. |
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'doc',
position: 'left',
docId: 'introduction',
label: 'Docs',
},
],
},
},
};
사이드바에 연결된 메뉴바
문서 ID를 하드코딩하지 않고 주어진 사이드바의 첫 번째 문서 링크(문서 링크 또는 생성된 카테고리 인덱스)에 메뉴바 항목을 연결할 수 있습니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'docSidebar' | 필수 | 메뉴바 아이템의 유형을 사이드바 첫 번째 문서로 설정합니다. |
sidebarId | string | 필수 | 아이템에서 링크로 연결되는 사이드바 ID입니다. |
label | string | 첫 번째 문서 링크의 사이드바 라벨 | 아이템을 표시하는 이름입니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
docsPluginId | string | 'default' | 사이드바가 속한 문서 플러그인 ID입니다. |
사이드바가 자주 업데이트되고 순서가 안정적이지 않은 경우에 이 메뉴바 항목 타입을 사용하세요.
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'docSidebar',
position: 'left',
sidebarId: 'api',
label: 'API',
},
],
},
},
};
export default {
tutorial: [
{
type: 'autogenerated',
dirName: 'guides',
},
],
api: [
'cli', // The navbar item will be linking to this doc
'docusaurus-core',
{
type: 'autogenerated',
dirName: 'api',
},
],
};
메뉴바 문서 버전 드롭다운
문서 버전 기능을 사용하고 있다면 특정 메뉴바 아이템 타입을 설정해 여러분의 사이트에서 사용할 수 있는 버전 목록을 드롭다운 목록으로 표시할 수 있습니다.
사용자는 같은 문서를 유지하면서 다른 버전으로 전환할 수 있습니다(버전 별 문서 ID가 같은 경우).
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'docsVersionDropdown' | 필수 | 항목 유형을 문서 버전 드롭다운으로 설정합니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
dropdownItemsBefore | LinkLikeItem[] | [] | 드롭다운 시작 부분에 드롭다운 아이템을 추가합니다. |
dropdownItemsAfter | LinkLikeItem[] | [] | 드롭다운 끝 부분에 드롭다운 아이템을 추가합니다. |
docsPluginId | string | 'default' | 문서 버전이 속한 문서 플러그인 ID입니다. |
dropdownActiveClassDisabled | boolean | false | 문서를 탐색할 때 링크 활성 클래스를 추가하지 않습니다. |
versions | DropdownVersions | undefined | Specify a custom list of versions to include in the dropdown. See the versioning guide for details. |
Types:
type DropdownVersion = {
/** Allows you to provide a custom display label for each version. */
label?: string;
};
type DropdownVersions = string[] | {[versionName: string]: DropdownVersion};
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'docsVersionDropdown',
position: 'left',
dropdownItemsAfter: [{to: '/versions', label: 'All versions'}],
dropdownActiveClassDisabled: true,
},
],
},
},
};
메뉴바 문서 버전
문서 버전 기능을 사용하고 있다면 특정 메뉴바 아이템 타입을 설정해 (현재 URL에 따라) 활성화되고 탐색하고 있는 문서 버전 링크로 연결할 수 있습니다. 설정이 없으면 최신 버전 링크로 연결합니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'docsVersion' | 필수 | 항목 유형을 문서 버전 링크로 설정합니다. |
label | string | 활성화/최신 버전 라벨 | 아이템을 표시하는 이름입니다. |
to | string | 활성화/최신 버전 | 아이템이 가리키는 내부 링크입니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
docsPluginId | string | 'default' | 문서 버전이 속한 문서 플러그인 ID입니다. |
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'docsVersion',
position: 'left',
to: '/path',
label: 'label',
},
],
},
},
};
메뉴바 로케일 드롭다운
i18n 기능을 사용하고 있다면 특정 메뉴바 아이템을 설정해 사이트에서 사용할 수 있는 로케일을 드롭다운 목록에 표시할 수 있습니다.
사용자는 같은 문서를 유지하면서 다른 언어로 전환할 수 있습니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'localeDropdown' | 필수 | 항목 유형을 로케일 드롭다운으로 설정합니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
dropdownItemsBefore | LinkLikeItem[] | [] | 드롭다운 시작 부분에 드롭다운 아이템을 추가합니다. |
dropdownItemsAfter | LinkLikeItem[] | [] | 드롭다운 끝 부분에 드롭다운 아이템을 추가합니다. |
queryString | string | undefined | The query string to be appended to the URL. |
설정 예시:
export default {
themeConfig: {
navbar: {
items: [
{
type: 'localeDropdown',
position: 'left',
dropdownItemsAfter: [
{
to: 'https://my-site.com/help-us-translate',
label: 'Help us translate',
},
],
},
],
},
},
};
메뉴바 검색
검색 기능을 사용하고 있다면 메뉴바 오른쪽 끝에 검색바가 표시됩니다.
하지만 특정 메뉴바 아이템을 설정해 기본 위치를 변경할 수 있습니다.
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'search' | 필수 | 항목 유형을 검색바로 설정합니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
className | string | / | 메뉴바 아이템을 위한 사용자 지정 CSS 클래스 |
export default {
themeConfig: {
navbar: {
items: [
{
type: 'search',
position: 'right',
},
],
},
},
};
메뉴바 사용자 지정 HTML
해당 메뉴바 아이템 타입을 사용해 메뉴바 아이템 내부에 여러분만의 HTML 마크업을 렌더링할 수 있습니다.
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
type | 'html' | 필수 | 항목 유형을 HTML 요소로 설정합니다. |
position | 'left' | 'right' | 'left' | 메뉴바에서 아이템이 표시되는 위치를 설정합니다. |
className | string | '' | 메뉴바 아이템을 위한 사용자 지정 CSS 클래스 |
value | string | '' | 메뉴바 아이템 내에서 렌더링할 사용자 지정 HTML입니다. |
export default {
themeConfig: {
navbar: {
items: [
{
type: 'html',
position: 'right',
value: '<button>Give feedback</button>',
},
],
},
},
};
메뉴바 자동 숨김
사용자가 페이지 스크롤 다운을 시작하면 자동으로 메뉴바가 숨겨지고 스크롤을 올리면 다시 보여지는 UI 기능을 활성화할 수 있습니다.
export default {
themeConfig: {
navbar: {
hideOnScroll: true,
},
},
};
메뉴바 스타일
테마 전환 기능을 비활성화하지 않고도 메뉴바의 스타일을 따로 설정할 수 있습니다. 선택한 스타일은 선택한 테마와 상관없이 항상 적용됩니다.
현재 설정할 수 있는 스타일 옵션은 2가지입니다. dark
, primary
(--ifm-color-primary
색상에 따라) 인피마 문서에서 적용될 스타일을 확인해볼 수 있습니다.
export default {
themeConfig: {
navbar: {
style: 'primary',
},
},
};
코드 블록
도큐사우루스에서는 Prism React Renderer를 사용해 코드 블록 구문 강조를 처리합니다. 모든 설정은 prism
오브젝트에서 처리합니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
theme | PrismTheme | palenight | light-theme 코드 블록에서 사용할 Prism 테마입니다. |
darkTheme | PrismTheme | palenight | dark-theme 코드 블록에서 사용할 Prism 테마입니다. |
defaultLanguage | string | undefined | The default language to use for code blocks not declaring any explicit language. |
magicComments | MagicCommentConfig[] | 아래를 참조하세요. | 매직 주석 목록입니다. |
type MagicCommentConfig = {
className: string;
line?: string;
block?: {start: string; end: string};
};
const defaultMagicComments = [
{
className: 'theme-code-block-highlighted-line',
line: 'highlight-next-line',
block: {start: 'highlight-start', end: 'highlight-end'},
},
];
테마
By default, we use Palenight as syntax highlighting theme. You can specify a custom theme from the list of available themes. 어두운 모드를 사이트에서 사용할 때는 다른 구문 강조 테마를 사용하도록 설정할 수도 있습니다.
설정 예시:
import {themes as prismThemes} from 'prism-react-renderer';
export default {
themeConfig: {
prism: {
theme: prismThemes.github,
darkTheme: prismThemes.dracula,
},
},
};
마크다운 구문을 강조해야 하는 경우 어두운 모드 구문 강조 테마 사용 시 다른 배경색을 설정해야 할 수도 있습니다. 적용 가이드를 참고하세요.
기본 언어
3개의 억음부호(```) 뒤에 언어를 설정하지 않았을 때 코드 블록에서 기본으로 적용할 언어를 설정할 수 있습니다. 유효한 언어명을 설정해주어야 하는 것은 주의해주세요.
설정 예시:
export default {
themeConfig: {
prism: {
defaultLanguage: 'javascript',
},
},
};
바닥글
themeConfig.footer
설정에서 바닥글에 로고나 저작권 정보를 추가할 수 있습니다. 로고는 static 디렉터리에 가져다 놓을 수 있습니다. 로고 URL은 메뉴바 로고와 같은 방식으로 처리됩니다.
설정할 수 있는 필드
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
logo | Logo | undefined | 로고 오브젝트 사용자 지정 메뉴바 로고를 참고하세요. |
copyright | string | undefined | 하단에 표시되는 저작권 문구 작성 시 사용자 지정 HTML도 사용할 수 있습니다. |
style | 'dark' | 'light' | 'light' | 바닥글 컴포넌트의 색상 테마입니다. |
links | (Column | FooterLink)[] | [] | 표시할 링크 그룹입니다. |
설정 예시:
export default {
themeConfig: {
footer: {
logo: {
alt: 'Meta Open Source Logo',
src: 'img/meta_oss_logo.png',
href: 'https://opensource.fb.com',
width: 160,
height: 51,
},
copyright: `Copyright © ${new Date().getFullYear()} My Project, Inc. Built with Docusaurus.`,
},
},
};
바닥글 링크
themeConfig.footer.links
설정에서 바닥글에 링크를 추가할 수 있습니다. 바닥글 구성에는 multi-column footers와simple footers 두 가지 유형이 있습니다.
다중 컬럼 바닥글 링크는 각 컬럼에 대한 title
과 FooterItem
목록이 있습니다.
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
title | string | undefined | 링크 섹션 라벨입니다. |
items | FooterItem[] | [] | 섹션 링크입니다. |
FooterItem
에서 사용할 수 있는 필드는 아래와 같습니다.
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
label | string | 필수 | 링크에 대해 표시할 텍스트입니다. |
to | string | 필수 | 웹 사이트 내에서 탐색을 위해 사용하는 클라이언트 라우팅입니다. 해당 값 앞에 baseUrl이 자동으로 추가됩니다. |
href | string | 필수 | 웹 사이트 외부 탐색을 위해 사용하는 전체 페이지 탐색입니다. to 또는 href 중 하나만 사용해야 합니다. |
html | string | undefined | 단순 링크 대신 HTML 패스스루(pass-through)를 렌더링합니다. html 필드를 설정한 경우에는 다른 옵션은 설정하지 않아야 합니다. |
다중 컬럼 구성 예제입니다.
export default {
footer: {
links: [
{
title: 'Docs',
items: [
{
label: 'Style Guide',
to: 'docs/',
},
{
label: 'Second Doc',
to: 'docs/doc2/',
},
],
},
{
title: 'Community',
items: [
{
label: 'Stack Overflow',
href: 'https://stackoverflow.com/questions/tagged/docusaurus',
},
{
label: 'Discord',
href: 'https://discordapp.com/invite/docusaurus',
},
{
label: 'X',
href: 'https://x.com/docusaurus',
},
{
html: `
<a href="https://www.netlify.com" target="_blank" rel="noreferrer noopener" aria-label="Deploys by Netlify">
<img src="https://www.netlify.com/img/global/badges/netlify-color-accent.svg" alt="Deploys by Netlify" width="114" height="51" />
</a>
`,
},
],
},
],
},
};
간단한 바닥글에는 행에 표시되는 FooterItem
목록이 있습니다.
간단한 구성 예제입니다.
export default {
footer: {
links: [
{
label: 'Stack Overflow',
href: 'https://stackoverflow.com/questions/tagged/docusaurus',
},
{
label: 'Discord',
href: 'https://discordapp.com/invite/docusaurus',
},
{
label: 'X',
href: 'https://x.com/docusaurus',
},
{
html: `
<a href="https://www.netlify.com" target="_blank" rel="noreferrer noopener" aria-label="Deploys by Netlify">
<img src="https://www.netlify.com/img/global/badges/netlify-color-accent.svg" alt="Deploys by Netlify" width="114" height="51" />
</a>
`,
},
],
},
};
목차
themeConfig.tableOfContents
에서 기본 목차를 설정할 수 있습니다.
옵션명 | 타입 | 기본값 | 설명 |
---|---|---|---|
minHeadingLevel | number | 2 | 목차에 표시되는 최소 제목 수준입니다. 2에서 6 사이의 값으로 설정할 수 있고 최댓값보다 작거나 같아야 합니다. |
maxHeadingLevel | number | 3 | 목차에 표시되는 최대 제목 수준입니다. 2에서 6 사이의 값으로 설정할 수 있습니다. |
설정 예시:
export default {
themeConfig: {
tableOfContents: {
minHeadingLevel: 2,
maxHeadingLevel: 5,
},
},
};
후크
useColorMode
색상 컨텍스트에 접근하기 위한 리액트 후크입니다. This context contains functions for selecting light/dark/system mode and exposes the current color mode and the choice from the user. The color mode values should not be used for dynamic content rendering (see below).
사용 예:
import {useColorMode} from '@docusaurus/theme-common';
const MyColorModeButton = () => {
const {
colorMode, // the "effective" color mode, never null
colorModeChoice, // the color mode chosen by the user, can be null
setColorMode, // set the color mode chosen by the user
} = useColorMode();
return (
<button
onClick={() => {
const nextColorMode = colorModeChoice === 'dark' ? 'light' : 'dark';
setColorMode(nextColorMode);
}}>
Toggle color mode
</button>
);
};
Attributes:
colorMode: 'light' | 'dark'
: The effective color mode currently applied to the UI. It cannot benull
.colorModeChoice: 'light' | 'dark' | null
: The color mode explicitly chosen by the user. It can benull
if user has not made any choice yet, or if they reset their choice to the system/default value.setColorMode(colorModeChoice: 'light' | 'dark' | null, options: {persist: boolean}): void
: A function to call when the user explicitly chose a color mode.null
permits to reset the choice to the system/default value. By default, the choice is persisted inlocalStorage
and restored on page reload, but you can opt out with{persist: false}
.
Don't use colorMode
and colorModeChoice
while rendering React components. Doing so is likely to produce FOUC, layout shifts and React hydration mismatches if you use them to render JSX content dynamically.
However, these values are safe to use after React hydration, in useEffect
and event listeners, like in the MyColorModeButton
example above.
If you need to render content dynamically depending on the current theme, the only way to avoid FOUC, layout shifts and hydration mismatch is to rely on CSS selectors to render content dynamically, based on the html
data attributes that we set before the page displays anything:
<html data-theme="<light | dark>" data-theme-choice="<light | dark | system>">
<!-- content -->
</html>
[data-theme='light']
[data-theme='dark']
[data-theme-choice='light']
[data-theme-choice='dark']
[data-theme-choice='system']
Why are colorMode
and colorModeChoice
unsafe when rendering?
To understand the problem, you need to understand how React hydration works.
During the static site generation phase, Docusaurus doesn't know what the user color mode choice is, and useColorMode()
returns the following static values:
colorMode = themeConfig.colorMode.defaultMode
colorModeChoice = null
During the very first React client-side render (the hydration), React must produce the exact same HTML markup, and will also use these static values.
The correct colorMode
and colorModeChoice
values will only be provided in the second React render.
Typically, the following component will lead to React hydration mismatches. The label may switch from light
to dark
while React hydrates, leading to a confusing user experience.
import {useColorMode} from '@docusaurus/theme-common';
const DisplayCurrentColorMode = () => {
const {colorMode} = useColorMode();
return <span>{colorMode}</span>;
};
useColorMode
를 호출하는 컴포넌트는 Layout
컴포넌트의 자식 요소이어야 합니다.
function ExamplePage() {
return (
<Layout>
<Example />
</Layout>
);
}
i18n
i18n 소개 문서를 먼저 확인해주세요.
번역 파일 위치
- Base 경로:
website/i18n/[locale]/docusaurus-theme-[themeName]
- 멀티 인스턴스 경로: 해당없음
- JSON 파일:
docusaurus write-translations
명령 실행 후 만들어진 파일 - 마크다운 파일: 해당없음
파일 시스템 구조 예
website/i18n/[locale]/docusaurus-theme-classic
│
│ # translations for the theme
├── navbar.json
└── footer.json