Astro에서 Markdown 사용하기
Markdown은 일반적으로 블로그 게시물 및 문서와 같이 텍스트가 많은 콘텐츠를 작성하는 데 사용됩니다. Astro에는 title, description, tags와 같은 사용자 정의 속성을 정의하기 위해 프런트매터 YAML도 포함할 수 있는 Markdown 파일에 대한 기본 지원이 포함되어 있습니다.
Astro에서는 GitHub Flavored Markdown으로 콘텐츠를 작성한 다음 .astro
컴포넌트에 이를 렌더링할 수 있습니다. 이는 콘텐츠용으로 설계된 친숙한 작성 형식과 Astro의 컴포넌트 구문 및 아키텍처의 유연성을 결합한 것입니다.
Markdown에 컴포넌트 및 JSX 표현식을 포함하는 등의 추가 기능을 사용하려면 @astrojs/mdx
통합을 추가하여 MDX로 Markdown 콘텐츠를 작성하세요.
Markdown 파일 구성하기
섹션 제목: Markdown 파일 구성하기로컬 Markdown 파일은 src/
디렉터리 내 어디에나 보관할 수 있습니다. 단일 로컬 Markdown 파일은 import
문을 사용하여 .astro
컴포넌트로 가져올 수 있으며, 여러 파일을 한 번에 쿼리하기 위해서는 Vite의 import.meta.glob()
을 사용할 수 있습니다.
연관된 Markdown 파일 그룹이 있는 경우 컬렉션으로 정의하는 것을 고려해 보세요. 이렇게 하면 파일 시스템의 어느 곳에나 또는 원격으로 Markdown 파일을 저장할 수 있는 등 여러 가지 이점이 있습니다.
컬렉션을 사용하면 콘텐츠별로 최적화된 API를 사용하여 콘텐츠를 쿼리하고 렌더링할 수도 있습니다. 컬렉션은 블로그 게시물이나 제품 항목과 같이 동일한 구조를 공유하는 데이터 집합을 위한 것입니다. 스키마에서 해당 형태를 정의하면 편집기에서 유효성 검사, 타입 안전, 인텔리센스를 사용할 수 있습니다.
동적 JSX 유사 표현식
섹션 제목: 동적 JSX 유사 표현식Markdown 파일을 가져오거나 쿼리한 후에는 프런트매터 데이터와 본문 콘텐츠를 포함하는 .astro
컴포넌트에 동적 HTML 템플릿을 작성할 수 있습니다.
사용 가능한 속성
섹션 제목: 사용 가능한 속성컬렉션 쿼리하기
섹션 제목: 컬렉션 쿼리하기도우미 함수를 통해 컬렉션에서 데이터를 가져올 때 Markdown의 frontmatter 속성은 data
객체 (예: post.data.title
)에서 사용할 수 있습니다. 또한 body
에는 컴파일되지 않은 원시 본문 콘텐츠가 문자열로 포함됩니다.
Markdown 가져오기
섹션 제목: Markdown 가져오기import
또는 import.meta.glob()
을 사용하여 Markdown을 가져올 때 내보낸 다음 속성은 .astro
컴포넌트에서 사용할 수 있습니다:
file
- 절대 파일 경로 (예:/home/user/projects/.../file.md
).url
- 페이지의 URL (예:/en/guides/markdown-content
).frontmatter
- 파일의 YAML 프런트매터에 지정된 모든 데이터를 포함합니다.<Content />
- 파일의 전체 렌더링된 콘텐츠를 반환하는 컴포넌트입니다.rawContent()
- 원시 Markdown 문서를 문자열로 반환하는 함수입니다.compiledContent()
- HTML 문자열로 컴파일된 Markdown 문서를 반환하는 함수입니다.getHeadings()
-{ depth: number; slug: string; text: string }[]
타입을 가지는 파일의 모든 제목 (예:<h1>
부터<h6>
)의 배열을 반환하는 비동기 함수입니다. 각 제목의slug
는 특정 제목에 대해 생성된 ID에 해당하며, 앵커 링크에 사용될 수 있습니다.
Markdown 블로그 게시물 예시에서는 다음 Astro.props
객체를 전달할 수 있습니다:
<Content />
컴포넌트
섹션 제목: <Content /> 컴포넌트<Content />
컴포넌트는 Markdown 파일에서 Content
를 가져와서 사용할 수 있습니다. 이 컴포넌트는 파일의 전체 본문 콘텐츠를 HTML로 렌더링하여 반환합니다. 선택적으로 Content
의 이름을 원하는 컴포넌트 이름으로 변경할 수 있습니다.
이와 유사하게 <Content />
컴포넌트를 렌더링하여 Markdown 컬렉션 항목의 HTML 콘텐츠를 렌더링을 할 수 있습니다.
제목 ID
섹션 제목: 제목 IDMarkdown으로 제목을 작성하면 자동으로 앵커 링크가 제공되므로 페이지의 특정 섹션으로 바로 연결할 수 있습니다.
Astro는 github-slugger
를 기반으로 제목의 id
를 생성합니다. 더 많은 예시는 github-slugger 문서에서 찾을 수 있습니다.
제목 ID와 플러그인
섹션 제목: 제목 ID와 플러그인Astro는 Markdown 및 MDX 파일의 모든 제목 요소 (<h1>
~ <h6>
)에 id
속성을 삽입하고 Markdown 내보낸 속성에서 이러한 ID를 검색하기 위한 getHeadings()
유틸리티를 제공합니다.
id
속성 (예: rehype-slug
)을 삽입하는 rehype 플러그인을 추가하여 이러한 제목 ID를 맞춤설정할 수 있습니다. Astro의 기본값 대신 사용자 정의 ID가 HTML 출력과 getHeadings()
에 의해 반환된 항목에 반영됩니다.
기본적으로 Astro는 rehype 플러그인이 실행된 후 id
속성을 주입합니다. 사용자 정의 rehype 플러그인 중 하나가 Astro에서 삽입한 ID에 액세스해야 하는 경우 Astro의 rehypeHeadingIds
플러그인을 직접 가져와 사용할 수 있습니다. 이를 사용하는 플러그인 앞에 rehypeHeadingIds
를 추가하세요.
Markdown 플러그인
섹션 제목: Markdown 플러그인Astro의 Markdown 지원은 활성 생태계를 갖춘 강력한 구문 분석 및 처리 도구인 remark를 통해 제공됩니다. Pandoc 및 markdown-it과 같은 다른 Markdown 파서는 현재 지원되지 않습니다.
Astro는 기본적으로 GitHub-flavored Markdown 및 SmartyPants 플러그인을 적용합니다. 이는 텍스트에서 클릭 가능한 링크 생성, 인용 및 em-dashes 서식 지정과 같은 몇 가지 장점을 제공합니다.
astro.config.mjs
파일에서 remark가 Markdown을 구문 분석하는 방법을 사용자 정의할 수 있습니다. Markdown 구성 옵션의 전체 목록을 확인하세요.
remark 및 rehype 플러그인 추가하기
섹션 제목: remark 및 rehype 플러그인 추가하기Astro는 Markdown에 대한 타사 remark 및 rehype 플러그인 추가를 지원합니다. 이러한 플러그인을 사용하면 목차 자동 생성, 접근 가능한 이모티콘 라벨 적용, Markdown 스타일 지정과 같은 새로운 기능으로 Markdown을 확장할 수 있습니다.
awesome-remark 및 awesome-rehype와 같은 인기 플러그인들을 찾아보시기 바랍니다! 구체적인 설치 지침은 각 플러그인의 자체 README를 참조하세요.
이 예시에서는 Markdown 파일에 remark-toc
및 rehype-accessible-emojis
를 적용합니다.
플러그인 사용자 정의
섹션 제목: 플러그인 사용자 정의플러그인을 사용자 정의하려면 중첩 배열에서 플러그인 뒤에 옵션 객체를 제공하세요.
아래 예시에서는 remarkToc
플러그인에 heading 옵션을 추가하여 목차 위치를 변경하고, rehype-autolink-headings
플러그인에 behavior
옵션을 추가하여 제목 텍스트 뒤에 앵커 태그를 추가했습니다.
프로그래밍 방식으로 프런트매터 수정하기
섹션 제목: 프로그래밍 방식으로 프런트매터 수정하기remark 또는 rehype 플러그인을 사용하여 모든 Markdown 및 MDX 파일에 프런트매터 속성을 추가할 수 있습니다.
-
플러그인의
file
인수에서data.astro.frontmatter
속성에customProperty
를 추가합니다.Added in: astro@2.0.0
data.astro.frontmatter
에는 특정 Markdown 또는 MDX 문서의 모든 속성이 포함되어 있습니다. 이를 통해 기존 프런트매터 속성을 수정하거나 기존 프런트매터에서 새 속성을 계산할 수 있습니다. -
이 플러그인을
markdown
또는mdx
통합 구성에 적용하세요.또는
이제 모든 Markdown 또는 MDX 파일의 프런트매터에 customProperty
가 있으므로 Markdown을 가져올 때 레이아웃의 Astro.props.frontmatter
속성에서 사용할 수 있습니다.
MDX에서 Markdown 구성 확장
섹션 제목: MDX에서 Markdown 구성 확장Astro의 MDX 통합은 기본적으로 프로젝트의 기존 Markdown 구성을 확장합니다. 개별 옵션을 재정의하려면 MDX 구성에서 해당 옵션을 지정하면 됩니다.
다음 예시에서는 GitHub 기반 Markdown을 비활성화하고 MDX 파일에 대해 다른 remark 플러그인 세트를 적용합니다.
MDX에서 Markdown 구성을 확장하지 않으려면 extendMarkdownConfig
옵션 (기본적으로 활성화됨)을 false
로 설정하세요.
구문 강조
섹션 제목: 구문 강조Astro에는 Shiki 및 Prism에 대한 지원이 내장되어 있습니다. 이는 다음에 대한 구문 강조를 제공합니다.
- Markdown 또는 MDX 파일에 사용되는 모든 코드 펜스(```).
- 내장
<Code />
컴포넌트의 콘텐츠 (Shiki 제공). <Prism />
컴포넌트의 콘텐츠 (Prism 제공).
Shiki는 기본적으로 활성화되어 있으며 github-dark
테마로 사전 구성되어 있습니다. 컴파일된 출력은 외부 CSS 클래스, 스타일시트 또는 클라이언트 측 JS가 없는 인라인 스타일
로 제한됩니다.
Shiki 구성
섹션 제목: Shiki 구성Shiki는 기본 구문 강조 도구입니다. 다음과 같이 shikiConfig
객체를 통해 모든 옵션을 구성할 수 있습니다.
.astro-code
클래스를 사용하여 Astro 코드 블록의 스타일을 지정합니다. Shiki의 문서를 따를 때는 (예: 라이트/다크 이중 테마 또는 다중 테마 사용자 지정하기) 예시에 있는 .shiki
클래스를 .astro-code
로 변경해야 합니다.
나만의 테마 추가하기
섹션 제목: 나만의 테마 추가하기Shiki의 사전 정의된 테마 중 하나를 사용하는 대신 로컬 파일에서 사용자 정의 테마를 가져올 수 있습니다.
또한 테마, 밝은 모드와 어두운 모드 전환 또는 CSS 변수를 통한 스타일 지정에 대해 자세히 알아보려면 Shiki의 자체 테마 문서를 읽어보는 것이 좋습니다.
기본 구문 강조
섹션 제목: 기본 구문 강조기본적으로 prism'
으로 전환하거나 구문 강조를 완전히 비활성화하려면 markdown.syntaxHighlight
구성 객체를 사용할 수 있습니다.
Prism 구성
섹션 제목: Prism 구성Prism을 사용하기로 선택한 경우 Astro는 대신 Prism의 CSS 클래스를 적용합니다. 구문 강조를 표시하려면 자신만의 CSS 스타일시트를 가져와야 합니다.
-
사용 가능한 Prism 테마에서 미리 만들어진 스타일시트를 선택합니다.
-
이 스타일시트를 프로젝트의
public/
디렉터리에 추가하세요. -
<link>
태그를 통해 레이아웃 컴포넌트에 있는 페이지의<head>
에 이를 로드합니다. (Prism 기본 사용법을 참고하세요.)
옵션 및 사용법을 알아보려면 Prism에서 지원하는 언어 목록을 방문하세요.
원격 마크다운 가져오기
섹션 제목: 원격 마크다운 가져오기Astro에는 실험적 콘텐츠 컬렉션 이외의 원격 Markdown에 대한 기본 지원은 포함되어 있지 않습니다!
원격 Markdown을 직접 가져와 HTML로 렌더링하려면 NPM에서 자체 Markdown 파서를 설치 및 구성해야 합니다. 이렇게 하면 사용자가 구성한 Astro의 기본 제공 Markdown 설정이 상속되지 않습니다.
이를 프로젝트에서 구현하기 전에 이러한 제한 사항을 이해하고, 대신 콘텐츠 컬렉션 로더를 사용하여 원격 마크다운을 가져오는 것을 고려하세요.
개별 Markdown 페이지
섹션 제목: 개별 Markdown 페이지콘텐츠 컬렉션과 Markdown을 .astro
컴포넌트로 가져오기는 Markdown 렌더링에 더 많은 기능을 제공하며, 대부분의 콘텐츠를 처리하는 데 권장되는 방식입니다. 하지만 src/pages/
에 파일을 추가하기만 하면 간단한 페이지가 자동으로 생성되는 편리함을 원할 때가 있습니다.
Astro는 .md
및 기타 Markdown 파일 유형을 포함하여 /src/pages/
디렉터리 내 지원되는 모든 파일을 페이지로 취급합니다.
이 디렉터리 또는 하위 디렉터리에 파일을 배치하면 파일 경로명을 사용하여 페이지 경로를 자동으로 빌드하고 HTML로 렌더링된 Markdown 콘텐츠가 표시됩니다.
프런트매터 layout
속성
섹션 제목: 프런트매터 layout 속성Markdown 페이지의 제한된 기능을 지원하기 위해, Astro는 Astro Markdown 레이아웃 컴포넌트에 대한 상대 경로인 특별한 프런트매터 layout
속성을 제공합니다. Markdown 파일이 src/pages/
에 있는 경우 레이아웃 컴포넌트를 생성하고 이 layout 속성에 추가하여 Markdown 콘텐츠 주위에 페이지 셸을 제공하세요.
이 레이아웃 컴포넌트는 Astro 템플릿의 Astro.props
를 통해 특정 속성을 자동으로 사용할 수 있는 일반 Astro 컴포넌트입니다. 예를 들어, Astro.props.frontmatter
를 통해 Markdown 파일의 프런트매터 속성에 액세스할 수 있습니다:
또한, 레이아웃 컴포넌트에서 Markdown 스타일을 지정할 수도 있습니다.