I want a scrollable table with fixed header. It looks like that's possible using opt_css. I used gt() argument id="scroll" to prevent the css from being applied to the subsequent table, but the subsequent table's column labels are misplaced--shoved all the way to the right.
Here's the .qmd and the rendered document. The yaml is format: html.
#| echo: FALSE
library(gt)
# Make some data.
dat1 <- data.frame(A=sample(15), B=sample(15), C=sample(15))
dat2 <- data.frame(D=sample(5), E=sample(5))
#| echo: false
gt(dat1, id = "scroll") |>
opt_css(css="
#scroll tbody {
display: block;
overflow-y: scroll;
max-height: 250px;
}
#scroll thead, tbody tr {
display: table;
width: calc(50% - 20px);
table-layout: fixed;
}
"
)
#| echo: false
gt(dat2)
