컴포넌트를 사용하면 쉽고 일관되게 UI 조각이나 스타일을 재사용할 수 있습니다.
링크 카드나 YouTube 삽입 등을 예로 들 수 있습니다.
Starlight는 MDX 파일에서 컴포넌트 사용을 지원하며 사용할 수 있는 몇 가지 공통 컴포넌트를 제공합니다.
Astro 문서에서 컴포넌트 구축에 대해 자세히 알아보세요 .
컴포넌트 사용
MDX 파일에서 컴포넌트를 가져온 다음 JSX 태그로 렌더링하여 사용할 수 있습니다.
이는 HTML 태그처럼 보이지만 import
문에 있는 이름과 일치하는 대문자로 시작합니다.
import SomeComponent from ' ~/components/SomeComponent.astro ' ;
import AnotherComponent from ' ~/components/AnotherComponent.astro ' ;
< SomeComponent prop = " 어떤 값 " />
컴포넌트에는 ** 중첩된 콘텐츠 ** 가 포함될 수도 있습니다.
Starlight는 Astro로 구동되므로 지원되는 UI 프레임워크(React, Preact, Svelte, Vue, Solid, Lit 및 Alpine) 로 빌드된 컴포넌트를 MDX 파일에 추가할 수 있습니다.
Astro 문서에서 MDX에서 컴포넌트 사용 에 대해 자세히 알아보세요.
Starlight 스타일과의 호환성
Starlight는 요소 사이에 여백을 추가하는 등 Markdown 콘텐츠에 기본 스타일을 적용합니다.
이러한 스타일이 컴포넌트의 모양과 충돌하는 경우 컴포넌트에 not-content
클래스를 추가하여 비활성화하세요.
< div class = " not-content " >
< p > Starlight의 기본 콘텐츠 스타일에 영향을 받지 않습니다. </ p >
내장된 컴포넌트
Starlight는 일반적인 문서 사용 사례를 위한 몇 가지 내장 컴포넌트를 제공합니다.
이러한 컴포넌트는 @astrojs/starlight/components
패키지를 통해 사용할 수 있습니다.
탭
<Tabs>
및 <TabItem>
컴포넌트를 사용하여 탭 인터페이스를 표시할 수 있습니다.
각 <TabItem>
은 사용자에게 보여줄 label
을 반드시 포함해야합니다.
label 옆에 Starlight 내장 아이콘 중 하나를 포함하려면 선택적 icon
속성을 사용하세요.
import { Tabs, TabItem } from ' @astrojs/starlight/components ' ;
< TabItem label = " 별 " icon = " star " >
< TabItem label = " 달 " icon = " moon " >
위 코드는 페이지에 아래와 같은 탭을 생성합니다.
동기화된 탭
syncKey
속성을 추가하여 여러 탭 그룹을 동기화된 상태로 유지합니다.
동일한 syncKey
값을 가진 페이지의 모든 <Tabs>
에는 동일한 활성 라벨이 표시됩니다. 이를 통해 독자는 한 번 (예: 운영 체제 또는 패키지 관리자) 선택하고 선택 사항이 페이지 전체에 반영되는 것을 볼 수 있습니다.
관련 탭을 동기화하려면 각 <Tabs>
컴포넌트에 동일한 syncKey
속성을 추가하고 모두 동일한 <TabItem>
라벨을 사용하는지 확인하세요.
import { Tabs, TabItem } from ' @astrojs/starlight/components ' ;
< TabItem label = " 오리온자리 " > 벨라트릭스, 리겔, 베텔게우스 </ TabItem >
< TabItem label = " 쌍둥이자리 " > 폴룩스, 캐스터 A, 캐스터 B </ TabItem >
< TabItem label = " 오리온자리 " > HD 34445 b, 글리제 179 b, Wasp-82 b </ TabItem >
< TabItem label = " 쌍둥이자리 " > 폴룩스 b, HAT-P-24b, HD 50554 b </ TabItem >
위 코드는 페이지에 다음을 생성합니다.
별:
외계 행성:
HD 34445 b, 글리제 179 b, Wasp-82 b 폴룩스 b, HAT-P-24b, HD 50554 b
카드
<Card>
컴포넌트를 사용하면 Starlight 스타일의 상자에 콘텐츠를 표시할 수 있습니다.
공간이 충분할 때 카드를 나란히 표시하려면 <CardGrid>
컴포넌트로 여러 카드를 감싸세요.
<Card>
컴포넌트에는 title
속성이 반드시 필요하며 선택적으로 Starlight 내장 아이콘 중 하나 의 이름으로 설정된 icon
속성을 포함할 수 있습니다.
import { Card, CardGrid } from ' @astrojs/starlight/components ' ;
< Card title = " 확인 " > 강조하고 싶은 흥미로운 콘텐츠. </ Card >
< Card title = " 별 " icon = " star " >
< Card title = " 달 " icon = " moon " >
위 코드는 페이지에 아래와 같은 요소들을 생성합니다.
확인
강조하고 싶은 흥미로운 콘텐츠.
링크 카드
다른 페이지로 이동하는 눈에 띄는 링크를 만들기 위해 <LinkCard>
컴포넌트를 사용하세요.
<LinkCard>
컴포넌트에는 title
과 href
속성이 필요합니다. 짧은 description
이나 target
과 같은 기타 링크 속성을 선택적으로 포함할 수 있습니다.
공간이 충분할 때, 카드를 나란히 표시하기 위해 여러 <LinkCard>
컴포넌트를 <CardGrid>
에 그룹화하세요.
import { LinkCard, CardGrid } from ' @astrojs/starlight/components ' ;
description = " 사용자 정의 스타일, 글꼴 등을 사용하여 나만의 Starlight 사이트를 만드는 방법을 알아보세요. "
href = " /ko/guides/customization/ "
href = " /ko/guides/authoring-content/ "
< LinkCard title = " 컴포넌트 " href = " /ko/guides/components/ " />
위 코드는 페이지에 아래와 같은 요소들을 생성합니다.
주석
“권고” 또는 “콜아웃”이라고도 하는 ‘주석’은 페이지의 기본 콘텐츠 옆에 보조 정보를 표시하는 데 유용합니다.
<Aside>
에는 note
(기본값), tip
, caution
또는 danger
등 선택적인 type
이 있을 수 있습니다. title
속성을 설정하면 주석의 기본 제목을 재정의합니다.
import { Aside } from ' @astrojs/starlight/components ' ;
< Aside > 제목을 설정하지 않은 기본 주석입니다. </ Aside >
< Aside type = " caution " title = " 주의! " >
< Aside type = " danger " > 여러분의 비밀번호를 누구에게도 알려주지 마세요. </ Aside >
위 코드는 페이지에 다음을 생성합니다.
위험
여러분의 비밀번호를 누구에게도 알려주지 마세요.
Starlight는 <Aside>
컴포넌트 대신 Markdown 및 MDX에서 Aside를 렌더링하기 위한 사용자 정의 구문도 제공합니다.
사용자 정의 구문에 대한 자세한 내용은 “마크다운으로 콘텐츠 작성” 가이드를 참조하세요.
코드
예를 들어 파일, 데이터베이스 또는 API와 같은 외부 소스에서 오는 데이터를 렌더링하기 위해 Markdown 코드 블록 을 사용할 수 없는 경우 <Code>
컴포넌트를 사용하여 구문 강조 코드를 렌더링합니다.
<Code>
가 지원하는 props에 대한 자세한 내용은 Expressive Code “Code Component” 문서 를 참조하세요.
import { Code } from ' @astrojs/starlight/components ' ;
export const exampleCode = ` console.log('This could come from a file or CMS!'); ` ;
export const fileName = ' example.js ' ;
export const highlights = [ ' file ' , ' CMS ' ];
< Code code = { exampleCode } lang = " js " title = { fileName } mark = { highlights } />
위 코드는 페이지에 다음을 생성합니다.
console . log ( ' This could come from a file or CMS ! ' );
가져온 코드
Vite의 ?raw
가져오기 접미사 를 사용하여 코드 파일을 문자열로 가져옵니다. 그런 다음 가져온 문자열을 <Code>
컴포넌트에 전달하여 페이지에 포함할 수 있습니다.
import { Code } from ' @astrojs/starlight/components ' ;
import importedCode from ' /src/env.d.ts ?raw ' ;
< Code code = { importedCode } lang = " ts " title = " src/env.d.ts " />
위 코드는 페이지에 다음을 생성합니다.
/// < reference path = " ../.astro/types.d.ts " />
/// < reference types = " astro/client " />
파일 트리
<FileTree>
컴포넌트를 사용하면 파일 아이콘과 축소 가능한 하위 디렉터리가 있는 디렉터리 구조를 표시할 수 있습니다.
<FileTree>
에서 순서가 지정되지 않은 Markdown 목록 을 사용하여 파일 및 디렉터리의 구조를 지정하세요.
중첩된 목록을 사용하여 하위 디렉터리를 생성하거나 목록 항목 끝에 /
를 추가하여 특정 내용이 없는 디렉터리로 렌더링합니다.
다음 구문을 사용하여 파일 트리의 모양을 사용자 정의할 수 있습니다.
이름을 굵게 표시하여 파일이나 디렉터리를 강조 표시합니다. 예: **README.md**
.
이름 뒤에 더 많은 텍스트를 추가하여 파일이나 디렉터리에 설명을 추가합니다.
...
또는 …
을 이름으로 사용하여 자리 표시자 파일과 디렉터리를 추가합니다.
import { FileTree } from ' @astrojs/starlight/components ' ;
- astro.config.mjs ** 중요 ** 파일
위 코드는 페이지에 다음을 생성합니다.
astro.config.mjs package.json README.mdDirectory src
Directory pages/
단계
<Steps>
컴포넌트를 사용하여 번호가 매겨진 작업 목록의 스타일을 지정합니다.
이는 각 단계를 명확하게 강조해야 하는 보다 복잡한 단계별 가이드에 유용합니다.
표준 Markdown 정렬 목록을 <Steps>
로 묶습니다.
모든 일반적인 Markdown 구문은 <Steps>
내에서 적용 가능합니다.
import { Steps } from ' @astrojs/starlight/components ' ;
import { Steps } from ' @astrojs/starlight/components ' ;
2 . 순서가 매겨진 목록 항목을 ` <Steps> ` 로 묶습니다.
위 코드는 페이지에 다음을 생성합니다.
컴포넌트를 MDX 파일로 가져옵니다.
import { Steps } from ' @astrojs/starlight/components ' ;
순서가 매겨진 목록 항목을 <Steps>
로 묶습니다.
배지
상태나 라벨과 같은 작은 정보를 표시하려면 <Badge>
컴포넌트를 사용하세요.
표시하려는 콘텐츠를 <Badge>
컴포넌트의 text
속성에 전달하세요.
기본적으로 배지는 사이트의 테마 강조 색상을 사용합니다. 내장 배지 색상을 사용하려면 variant
속성의 값을 note
(파란색), tip
(보라색), danger
(빨간색), caution
(주황색), ‘success’(녹색) 중 하나로 설정하세요. .
size
속성 (기본값: small
)은 배지의 텍스트 크기를 제어합니다. 더 큰 배지를 표시하기 위해 medium
및 large
옵션도 사용할 수 있습니다.
맞춤 설정이 더 필요하다면 사용자 정의 CSS와 함께 class
또는 style
과 같은 다른 <span>
속성을 사용하세요.
import { Badge } from ' @astrojs/starlight/components ' ;
< Badge text = " New " variant = " tip " size = " small " />
< Badge text = " Deprecated " variant = " caution " size = " medium " />
< Badge text = " Starlight " variant = " note " size = " large " />
< Badge text = " Custom " variant = " success " style = { { fontStyle: ' italic ' } } />
위의 코드는 페이지에 다음을 생성합니다.
New
Deprecated
Starlight
Custom
아이콘
Starlight는 <Icon>
컴포넌트를 사용하여 콘텐츠에 표시할 수 있는 공통 아이콘 세트를 제공합니다.
각 <Icon>
에는 name
이 필요하며 스크린 리더에 컨텍스트를 제공하기 위해 선택적으로 label
을 포함할 수 있습니다.
CSS 단위와 색상 값을 사용하여 아이콘의 모양을 조정하는 데 size
및 color
속성을 사용할 수 있습니다.
import { Icon } from ' @astrojs/starlight/components ' ;
< Icon name = " star " color = " goldenrod " size = " 2rem " />
< Icon name = " rocket " color = " var(--sl-color-text-accent) " />
위 코드는 페이지에 다음을 생성합니다.
모든 아이콘
사용 가능한 모든 아이콘 목록이 관련 이름과 함께 아래에 표시됩니다. 아이콘을 클릭하면 해당 컴포넌트의 코드를 복사할 수 있습니다.
up-caret down-caret right-caret right-arrow left-arrow bars translate pencil pen document add-document setting external moon sun laptop open-book information magnifier forward-slash close error warning approve-check-circle approve-check rocket star puzzle list-format random comment comment-alt heart github gitlab bitbucket codePen farcaster discord gitter twitter x.com mastodon codeberg youtube threads linkedin twitch microsoftTeams instagram stackOverflow telegram rss facebook email reddit patreon signal slack matrix hackerOne openCollective blueSky discourse astro alpine pnpm biome bun mdx apple linux homebrew nix starlight pkl node cloudflare vercel netlify deno seti:folder seti:bsl seti:mdo seti:salesforce seti:asm seti:bicep seti:bazel seti:c seti:c-sharp seti:html seti:cpp seti:clojure seti:coldfusion seti:config seti:crystal seti:crystal_embedded seti:json seti:css seti:csv seti:xls seti:cu seti:cake seti:cake_php seti:d seti:word seti:elixir seti:elixir_script seti:hex seti:elm seti:favicon seti:f-sharp seti:git seti:go seti:godot seti:gradle seti:grails seti:graphql seti:hacklang seti:haml seti:mustache seti:haskell seti:haxe seti:jade seti:java seti:javascript seti:jinja seti:julia seti:karma seti:kotlin seti:dart seti:liquid seti:livescript seti:lua seti:markdown seti:argdown seti:info seti:clock seti:maven seti:nim seti:github seti:notebook seti:nunjucks seti:npm seti:ocaml seti:odata seti:perl seti:php seti:pipeline seti:pddl seti:plan seti:happenings seti:powershell seti:prisma seti:pug seti:puppet seti:purescript seti:python seti:react seti:rescript seti:R seti:ruby seti:rust seti:sass seti:spring seti:slim seti:smarty seti:sbt seti:scala seti:ethereum seti:stylus seti:svelte seti:swift seti:db seti:terraform seti:tex seti:default seti:twig seti:typescript seti:tsconfig seti:vala seti:vue seti:wasm seti:wat seti:xml seti:yml seti:prolog seti:zig seti:zip seti:wgt seti:illustrator seti:photoshop seti:pdf seti:font seti:image seti:svg seti:sublime seti:code-search seti:shell seti:video seti:audio seti:windows seti:jenkins seti:babel seti:bower seti:docker seti:code-climate seti:eslint seti:firebase seti:firefox seti:gitlab seti:grunt seti:gulp seti:ionic seti:platformio seti:rollup seti:stylelint seti:yarn seti:webpack seti:lock seti:license seti:makefile seti:heroku seti:todo seti:ignored