FontFamily Type — astro Architecture
Architecture documentation for the FontFamily type/interface in types.ts from the astro codebase.
Entity Profile
Dependency Diagram
graph TD 73feed19_0973_8ad6_59d8_9f3851b6c52e["FontFamily"] 0414cf8f_0404_f03b_316f_0d732aa66968["types.ts"] 73feed19_0973_8ad6_59d8_9f3851b6c52e -->|defined in| 0414cf8f_0404_f03b_316f_0d732aa66968 style 73feed19_0973_8ad6_59d8_9f3851b6c52e fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
packages/astro/src/assets/fonts/types.ts lines 121–191
export type FontFamily<TFontProvider extends FontProvider = FontProvider> = FamilyProperties &
WithOptions<NoInfer<TFontProvider>> & {
/**
* The font family name, as identified by your font provider.
*/
name: string;
/**
* A valid [ident](https://developer.mozilla.org/en-US/docs/Web/CSS/ident) in the form of a CSS variable (i.e. starting with `--`).
*/
cssVariable: string;
/**
* The source of your font files. You can use a built-in provider or write your own custom provider.
*/
provider: TFontProvider;
/**
* @default `[400]`
*
* An array of [font weights](https://developer.mozilla.org/en-US/docs/Web/CSS/font-weight). If no value is specified in your configuration, only weight `400` is
* included by default to prevent unnecessary downloads. You will need to include this property to access any other font weights.
*
* If the associated font is a [variable font](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_fonts/Variable_fonts_guide), you can specify a range of weights:
*
* ```js
* weight: "100 900"
* ```
*/
weights?: [Weight, ...Array<Weight>] | undefined;
/**
* @default `["normal", "italic"]`
*
* An array of [font styles](https://developer.mozilla.org/en-US/docs/Web/CSS/font-style).
*/
styles?: [Style, ...Array<Style>] | undefined;
/**
* @default `["latin"]`
*
* Defines a list of [font subsets](https://knaap.dev/posts/font-subsetting/).
*/
subsets?: [string, ...Array<string>] | undefined;
/**
* @default `["woff2"]`
*
* An array of [font formats](https://developer.mozilla.org/en-US/docs/Web/CSS/Reference/At-rules/@font-face/src#font_formats).
*/
formats?: [FontType, ...Array<FontType>] | undefined;
/**
* @default `["sans-serif"]`
*
* An array of fonts to use when your chosen font is unavailable, or loading. Fallback fonts will be chosen in the order listed. The first available font will be used:
*
* ```js
* fallbacks: ["CustomFont", "serif"]
* ```
*
* To disable fallback fonts completely, configure an empty array:
*
* ```js
* fallbacks: []
* ```
*
* If the last font in the `fallbacks` array is a [generic family name](https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#generic-name), Astro will attempt to
* generate [optimized fallbacks](https://developer.chrome.com/blog/font-fallbacks) using font metrics will be generated. To disable this optimization, set `optimizedFallbacks` to false.
*/
fallbacks?: Array<string> | undefined;
/**
* @default `true`
*
* Whether or not to enable Astro's default optimization when generating fallback fonts. You may disable this default optimization to have full control over how `fallbacks` are generated.
*/
optimizedFallbacks?: boolean | undefined;
};
Defined In
Source
Frequently Asked Questions
What is the FontFamily type?
FontFamily is a type/interface in the astro codebase, defined in packages/astro/src/assets/fonts/types.ts.
Where is FontFamily defined?
FontFamily is defined in packages/astro/src/assets/fonts/types.ts at line 121.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free