Reflex allows you to add custom stylesheets. Simply pass the URLs of the stylesheets to rx.App
:
app = rx.App( stylesheets=[ "https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css", ], )
You can also add local stylesheets. Just put the stylesheet under assets/
and pass the path to the stylesheet to rx.App
:
app = rx.App( stylesheets=[ "/styles.css", # This path is relative to assets/ ], )
You can take advantage of Reflex's support for custom stylesheets to add custom fonts to your app.
In this example, we will use the IBM Plex Mono font from Google Fonts. First, add the stylesheet with the font to your app. You can get this link from the "Get embed code" section of the Google font page.
app = rx.App( stylesheets=[ "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap", ], )
Then you can use the font in your component by setting the font_family
prop.
Check out my font
rx.text(
"Check out my font",
font_family="IBM Plex Mono",
font_size="1.5em",
)
By making use of the two previous points, we can also make a stylesheet that allow you to use a font hosted on your server.
If your font is called MyFont.otf
, copy it in assets/fonts
.
Now we have the font ready, let's create the stylesheet myfont.css
.
@font-face { font-family: MyFont; src: url("/fonts/MyFont.otf") format("opentype"); } @font-face { font-family: MyFont; font-weight: bold; src: url("/fonts/MyFont.otf") format("opentype"); }
Add the reference to your new Stylesheet in your App.
app = rx.App( stylesheets=[ "/fonts/myfont.css", # This path is relative to assets/ ], )
And that's it! You can now use MyFont
like any other FontFamily to style your components.