| Type: | Package |
| Title: | Lightweight Tables via JSON Specs and JavaScript |
| Version: | 0.1 |
| Description: | A lightweight grammar of tables. Build a table by declaring a JSON spec (titles, spanners, row groups, footnotes, formatters, etc.); a tiny vanilla JavaScript runtime builds the HTML table from the spec on page load. No 'sass', no 'V8', no 'htmlwidgets' — just base R and 'xfun' ('htmltools' is used only for the optional Shiny binding). |
| License: | MIT + file LICENSE |
| URL: | https://github.com/yihui/lt |
| BugReports: | https://github.com/yihui/lt/issues |
| Depends: | R (≥ 4.1.0) |
| Encoding: | UTF-8 |
| Imports: | xfun (≥ 0.59) |
| Suggests: | htmltools, knitr, litedown, repr, shiny, testit |
| Config/lt.js: | 1.14.57 |
| Config/roxygen2/version: | 8.0.0 |
| NeedsCompilation: | no |
| Packaged: | 2026-06-25 00:34:31 UTC; yihui |
| Author: | Yihui Xie |
| Maintainer: | Yihui Xie <xie@yihui.name> |
| Repository: | CRAN |
| Date/Publication: | 2026-06-30 19:30:02 UTC |
lt: Lightweight Tables via JSON Specs and JavaScript
Description
A small grammar of tables. A table is a data frame plus a list of operations (title, spanner, footnote, ...); the operations are serialized to a JSON spec and applied to a plain semantic HTML table by a tiny vanilla JavaScript runtime at render time.
Author(s)
Maintainer: Yihui Xie xie@yihui.name (ORCID) (URL: https://yihui.org) [copyright holder]
Authors:
Yihui Xie xie@yihui.name (ORCID) (URL: https://yihui.org) [copyright holder]
See Also
Useful links:
Report bugs at https://github.com/yihui/lt/issues
Render an lt_tbl to HTML
Description
Emits the CSS+JS runtime and a script block carrying the table's JSON spec. Multiple tables on the same page only need the runtime once.
Usage
## S3 method for class 'lt_tbl'
format(x, fragment = TRUE, inline_assets = TRUE, assets = TRUE, ...)
Arguments
x |
An |
fragment |
If |
inline_assets |
If |
assets |
If |
... |
Reserved for future use. |
Value
A character scalar containing HTML.
Examples
tbl = lt(head(mtcars))
html = format(tbl)
format(tbl, fragment = FALSE, inline_assets = FALSE)
Create a Table Specification
Description
Entry point of the lightweight grammar of tables. Returns an object (a
list) that records the data plus a list of table-modifying operations. The
object is rendered to HTML by format() (called automatically by the
print method).
Usage
lt(data, ...)
## Default S3 method:
lt(data, auto_format = TRUE, auto_label = TRUE, ...)
Arguments
data |
A data frame (or anything coercible to one). |
... |
Arguments passed to methods. |
auto_format |
Whether to automatically format numeric columns (rounding,
thousand separators, percentage detection). Set to |
auto_label |
Whether to automatically clean column names for display
by replacing separators ( |
Value
A table object that can be piped into lt_*() functions.
Examples
lt(head(mtcars[, 1:4]))
Set Column Alignment
Description
Override the auto-detected alignment for specific columns. By default, numeric columns are right-aligned and character columns are left-aligned.
Usage
lt_align(x, columns, align = c("left", "center", "right"))
Arguments
x |
An |
columns |
Character vector of column names (or a one-sided formula). |
align |
One of |
Value
x with the alignment recorded.
Examples
lt(head(mtcars)) |> lt_align(~ cyl + gear, "center")
Attach Custom CSS
Description
Add user-supplied stylesheets or inline rules that render after the built-in CSS, so rules can override the defaults.
Usage
lt_css(x, ...)
Arguments
x |
An |
... |
Unnamed arguments are stylesheet paths or URLs. A bare
filename (no directory component) that does not exist in the working
directory is resolved against the stylesheets shipped with lt, so
e.g. Named arguments define inline CSS rules scoped to |
Value
x with the stylesheets recorded.
Examples
tbl = lt(head(mtcars))
tbl |>
lt_style("mpg", test = "v => v > 20", class = "high") |>
lt_css(.high = list(background = "#cfc", fontWeight = "bold"))
Format Date/Time Columns
Description
Format date or datetime columns using JavaScript's native Date methods.
The underlying data should be Date or POSIXt in R (serialized as
new Date(...) for the browser).
Usage
lt_date(x, columns, method = NULL, locale = NULL, options = NULL)
Arguments
x |
An |
columns |
Column selection (formula, character, or numeric). |
method |
A JS Date method name to call (e.g., |
locale |
A BCP 47 locale string (e.g., |
options |
A named list of
|
Value
x with the date formatting recorded.
Note
The formatted date may differ from the input date depending on the
viewer's local timezone. JavaScript's new Date("2024-01-15") parses
date-only strings as UTC midnight, but toLocaleDateString() converts to
the local timezone. For example, 2024-01-15 will display as
2024-01-14 for a viewer at GMT-6. To avoid this, pass
options = list(timeZone = "UTC").
Examples
d = data.frame(
event = c("Launch", "Update"),
date = as.Date(c("2024-01-15", "2024-06-30"))
)
lt(d) |> lt_date(~ date)
lt(d) |> lt_date(~ date, options = list(year = "numeric", month = "short"))
Add a Footnote
Description
Attaches a footnote text to a table region. Footnotes are numbered
automatically in the order they are added (de-duplicated by text).
Usage
lt_footnote(x, text, where, columns = NULL, rows = NULL, match = NULL)
Arguments
x |
An |
text |
Footnote text. |
where |
One of |
columns |
Character vector of column names or a one-sided formula (for
|
rows |
Integer vector of 1-based row indices (for |
match |
For |
Value
x with the footnote recorded.
Examples
lt(head(mtcars)) |>
lt_footnote("Source: 1974 Motor Trend US magazine.", "title")
Format Numeric Columns
Description
Control the number of decimal places and thousands separator for numeric
columns. Columns passed to this function are excluded from automatic
formatting (see the auto_format argument of lt()). To disable auto-format
for a column without otherwise changing its display, call lt_format(x, ~col) with no other arguments.
Usage
lt_format(
x,
columns,
decimals = NULL,
big_mark = NULL,
percent = NULL,
prefix = NULL,
suffix = NULL
)
Arguments
x |
An |
columns |
Character or integer vector of columns (or a one-sided formula). |
decimals |
Number of decimal places (default |
big_mark |
Thousands separator (e.g., |
percent |
If |
prefix |
String prepended to each formatted value (e.g., |
suffix |
String appended to each formatted value (e.g., |
Value
x with the formatting recorded.
Examples
lt(head(mtcars)) |> lt_format(~ mpg + wt, decimals = 1, big_mark = ",")
d = data.frame(Item = c("A", "B"), Price = c(1234.5, 678.9))
lt(d) |> lt_format(~ Price, decimals = 2, big_mark = ",", prefix = "$")
Define Row Groups
Description
Partition rows into labeled groups. Pass column names to group by those
columns' values (the columns are removed from the body and rendered as
rowspan cells on the left). Use sep = TRUE to render groups as
full-width separator rows instead of rowspan.
Usage
lt_group(x, ..., sep = "auto", sort = TRUE)
Arguments
x |
An |
... |
A column name or formula (e.g., |
sep |
If |
sort |
If |
Value
x with the row groups recorded.
Examples
# Group by a column (rowspan, default)
d = data.frame(arm = c("Placebo", "Placebo", "Treatment", "Treatment"),
stat = c("n", "Mean", "n", "Mean"), value = c(30, 4.2, 31, 6.8))
lt(d) |> lt_group(~ arm)
# Separator-row style
lt(d) |> lt_group(~ arm, sep = TRUE)
# Manual groups (always separator rows)
lt(head(mtcars)) |>
lt_group("First three" = 1:3, "Last three" = 4:6)
Add a Title and Subtitle
Description
Add a Title and Subtitle
Usage
lt_header(x, title = NULL, subtitle = NULL)
Arguments
x |
An |
title |
A character scalar. |
subtitle |
A character scalar. |
Value
x with the header recorded.
Examples
lt(head(mtcars)) |> lt_header("Motor Trend Cars", "First 6 rows")
Indent Rows
Description
Add hierarchical indentation to the first column of specified rows.
Usage
lt_indent(x, rows, level = 1)
Arguments
x |
An |
rows |
Integer vector of 1-based row indices to indent. |
level |
Indent level (default 1). Each level adds one unit of left padding. |
Value
x with the indentation recorded.
Examples
d = data.frame(label = c("Overall", "Male", "Female"), n = c(100, 55, 45))
lt(d) |> lt_indent(2:3)
Rename Column Labels
Description
Override column headers without modifying the underlying data frame.
Usage
lt_label(x, ...)
Arguments
x |
An |
... |
Named arguments of the form |
Value
x with the column label overrides recorded.
Examples
lt(head(mtcars)) |> lt_label(mpg = "Miles/Gallon", cyl = "Cylinders")
Merge Columns
Description
Combine values from multiple columns into a single display column using a pattern. Source columns (all except the first) are hidden by default.
Usage
lt_merge(x, columns, pattern = NULL, hide = TRUE)
Arguments
x |
An |
columns |
Character vector of column names (or a one-sided formula). The first column is the target (receives merged content); the rest are sources. |
pattern |
A glue-style template using |
hide |
If |
Value
x with the merge recorded.
Examples
d = data.frame(stat = c("Mean", "SD"), value = c(4.2, 1.1), ci = c("(2.0, 6.4)", "(0.5, 1.7)"))
lt(d) |> lt_merge(~ value + ci, pattern = "{1} {2}")
Move Columns
Description
Rearrange column display order without modifying the data frame.
Usage
lt_move(x, columns, after = NULL)
Arguments
x |
An |
columns |
Character vector of column names (or a one-sided formula). |
after |
Column name after which to place the moved columns. Use
|
Value
x with the column move recorded.
Examples
lt(head(mtcars)) |> lt_move(~ gear + carb, after = "mpg")
Add a Note
Description
Notes are rendered in the table footer below numbered footnotes.
Usage
lt_note(x, text)
Arguments
x |
An |
text |
Note text. |
Value
x with the note recorded.
Examples
lt(head(mtcars)) |> lt_note("CI = confidence interval.")
Shiny Bindings for lt
Description
lt_output() creates a UI placeholder; render_lt() supplies the table
spec from the server. Together they render an lt() table as a custom
Shiny output — no renderUI() involved.
Usage
lt_output(outputId, ...)
render_lt(expr, env = parent.frame(), quoted = FALSE)
Arguments
outputId |
Output variable name to read the table from. |
... |
Reserved for future use. |
expr |
An expression that returns an |
env |
Environment in which to evaluate |
quoted |
Whether |
Value
lt_output() returns a Shiny UI element; render_lt() returns a
render function.
Examples
if (interactive()) {
library(shiny)
ui = fluidPage(lt_output("tbl"))
server = function(input, output) {
output$tbl = render_lt(lt(head(mtcars)) |> lt_header("Motor Trend"))
}
shinyApp(ui, server)
}
Add a Column Spanner
Description
A spanner is a label rendered above a contiguous group of column headers.
Usage
lt_spanner(x, label, columns, sep = "[._]")
Arguments
x |
An |
label |
A character scalar — the spanner text. Alternatively, a
two-sided formula |
columns |
Column names (character or formula). When missing, inferred from column names. |
sep |
Separator pattern for auto-inference (default |
Details
When called with no label or columns, infers spanners from column
names by splitting on the first . or _ separator. Contiguous columns
sharing a prefix are grouped under that prefix, and column labels are
shortened to the suffix.
Value
x with the spanner recorded.
Note
The columns must be contiguous in the body of the table.
Examples
tbl = lt(head(iris))
# Explicit spanner
tbl |> lt_spanner(Sepal ~ Sepal.Length + Sepal.Width)
# Auto-infer from column names
tbl |> lt_spanner()
Style Cells
Description
Apply CSS styling to specific cells. Target cells by column, row, or both.
When test is provided, styles are applied conditionally based on cell
values (evaluated in JavaScript).
Usage
lt_style(
x,
columns = NULL,
rows = NULL,
test = NULL,
class = NULL,
bold = NULL,
italic = NULL,
color = NULL,
bg = NULL,
...
)
Arguments
x |
An |
columns |
Character vector of column names, a one-sided formula, or
|
rows |
Integer vector of 1-based row indices (or |
test |
A JavaScript function as a string (e.g., |
class |
CSS class name(s) to add to matching cells. Define the
corresponding rules in an external stylesheet via |
bold |
Logical: apply bold weight? |
italic |
Logical: apply italic style? |
color |
Text color (any CSS color value, e.g., |
bg |
Background color. |
... |
Additional CSS properties as named arguments. Names can be
camelCase (e.g., |
Value
x with the style recorded.
Examples
tbl = lt(head(mtcars))
tbl |>
lt_style("mpg", rows = 1L, bold = TRUE, borderBottom = "2px solid red")
tbl |>
lt_style("mpg", test = "v => v > 20", class = "high") |>
lt_css(.high = list(background = "#cfc"))
Substitute Cell Values
Description
Replace NA, zero, or small values with display text.
Usage
lt_sub(
x,
columns = NULL,
missing = NULL,
zero = NULL,
small = NULL,
small_text = NULL
)
Arguments
x |
An |
columns |
Character vector of column names, a one-sided formula, or
|
missing |
Replacement for |
zero |
Replacement for zero values (e.g., |
small |
Threshold: values whose absolute value is below this are
replaced by |
small_text |
Text shown for values below |
Value
x with the substitution recorded.
Examples
d = data.frame(x = c(1, 0, NA, 0.001))
lt(d) |> lt_sub(missing = "—", zero = "—", small = 0.01, small_text = "<0.01")
Set Column Widths
Description
Set Column Widths
Usage
lt_width(x, ...)
Arguments
x |
An |
... |
Named arguments of the form |
Value
x with the column widths recorded.
Examples
lt(head(mtcars)) |> lt_width(mpg = "100px", cyl = "50px")
Print an lt_tbl (Opens in the Viewer or Browser)
Description
Print an lt_tbl (Opens in the Viewer or Browser)
Usage
## S3 method for class 'lt_tbl'
print(x, ...)
Arguments
x |
An |
... |
Passed to |
Value
x, invisibly.
Examples
print(lt(head(mtcars)))