-
Notifications
You must be signed in to change notification settings - Fork 0
Default Layout
The default layout is used for most of your slides and -as its name implies- is used whenever you do not specify a layout for your slide.
Name | Type | Description | Default |
---|---|---|---|
color | String | Which color to setup as slidev-theme-primary for that slide |
kul-blue-600 |
content-class | String | CSS classes to add to the ::content:: slot wrapper div |
Roughly speaking, the default layout is constructed as follows:
<div class="slidev-layout flex flex-col">
<div class="slot-default">
<slot />
</div>
<div class="slot-content flex-grow">
<slot name="slot-content" />
</div>
</div>
As you can see it is perfectly valid to place all of your content in the ::default::
slot.
We even provide some default styling for your content in there (first element if it is a title, and some default margin for all others).
However, sometimes you want to be able to center your content vertically or use the remaining space of the slide in a different way.
This is where the ::content::
slot comes in.
By adding a flex-grow
, the wrapper around the content will effectively grow to take up all remaining space of the slide, allowing you to more easily organize your content.
Because this slot is meant for more advanced placement, it does not provide any default styling of its children whatsoever.
HINT
It is fairly straightforward to place your::content::
by applying some UnoCSS classes through thecontent-class
argument. In fact, that is exactly how a lot of the other layouts were made (eg. cluster, column, pile, stack). Feel free to use these predefined layouts are construct your own!
This slot allows you to add some text in the footer (next to the eavise icon).
By default the text is slightly smaller and colored similarly to the rest of the footer, though it is easily overridable by providing your own styles for :deep(.slot-footer)
.
Default
---
# Slide Title
*inline content*
If you add two spaces after a line it will add a `<br />`.
Tempor culpa minim tempor culpa nisi Lorem ad.
- lists
- are
- great
--- |
Minimal
<!-- Set `style: minimal` in the top frontmatter -->
---
# Slide Title
*inline content*
If you add two spaces after a line it will add a `<br />`.
Tempor culpa minim tempor culpa nisi Lorem ad.
- lists
- are
- great
--- |
Content Slot
---
content-class: flex flex-col text-center justify-center
---
# Slide Title
::content::
We center the slot content by using `display: flex`.
Tempor culpa minim tempor culpa nisi Lorem ad.
--- |
Footer Slot
---
# Slide Title
*inline content*
::footer::
This is a footer text
Two lines is probably the maximum that fits well in here...
--- |