Cross-Reference Div Syntax
Overview
Cross-referenceable figures, tables and code listings are known as float cross-references. Floats can appear in the rendered document at locations other than where they are defined, i.e. they float, and usually have captions.
Along with compact syntax for the most common uses of cross-references, Quarto also provides a more general div syntax for declaring floats that can be cross-referenced. To declare a cross-referenceable float, place the content inside a fenced div with the reference identifier as an attribute. The last paragraph inside the fenced div will be treated as the caption. For example:
::: {#fig-example}
CONTENT
Caption
:::
To be recognized as a cross-reference the identifier must begin with one of the built-in float reference types (Figures (fig-
), Tables (tbl-
) and Listings (lst-
)), or be defined as a custom float cross-reference type.
You can then refer to the element as usual with the @
syntax, e.g.
@fig-example shows...
The content can be any Quarto markdown. For example, Figure 1 is a markdown table treated like a figure:
::: {#fig-table}
| A | B |
|---|---|
| C | D |
A table treated like a figure
:::
A | B |
---|---|
C | D |
Table 1 is an image treated like a table:
::: {#tbl-table}
![](table.png)
An image treated like a table
:::
Figure 2 is a code cell treated like a figure:
::: {#fig-code}
```r
library(tidyverse)
|>
starwars ggplot(aes(height, mass)) +
geom_point()
```
A code cell treated like a figure.
:::
On this page, we illustrate common use cases for Figures, Tables and Code Listings then some applications of the div syntax to:
Figures
To create a cross-reference to a figure using div syntax, create a fenced div with an id starting with fig-
, include the image followed by the caption inside the div:
::: {#fig-elephant}
![](elephant.png)
An Elephant :::
You can cross-reference a figure created by an executable code cell by including the code cell as the content:
::: {#fig-line-plot}
```{python}
import matplotlib.pyplot as plt
1,23,2,4])
plt.plot([
plt.show()```
A line plot :::
In the above example, you can reference the figure with @fig-line-plot
, but not the code, which appears inline. If you would also like to be able to refer to the code, you can do so using code chunk options rather than the div syntax, see Cross-References for Executable Code Blocks for details.
Tables
To create a cross-reference to a table using div syntax, create a fenced div with an id starting with tbl-
, include the table followed by the caption inside the div:
::: {#tbl-letters}
| Col1 | Col2 | Col3 |
|------|------|------|
| A | B | C |
| E | F | G |
| A | G | G |
My Caption
:::
If the table is produced by an executable code cell, put the cell inside the div as content, e.g:
::: {#tbl-planets}
```{python}
from IPython.display import Markdown
from tabulate import tabulate
= [["Sun","696,000",1.989e30],
table "Earth","6,371",5.972e24],
["Moon","1,737",7.34e22],
["Mars","3,390",6.39e23]]
[
Markdown(tabulate(
table, =["Astronomical object","R (km)", "mass (kg)"]
headers
))```
Astronomical object
:::
In the above example, you can reference the table with @tbl-planets
, but not the code, which appears inline. If you would also like to be able to refer to the code, you can do so using code chunk options rather than the div syntax, see Cross-References for Executable Code Blocks for details.
Listings
To create a cross-reference to a code listing using div syntax, create a fenced div with an id starting with lst-
, include the code cell followed by the caption inside the div:
::: {#lst-customers}
```{.sql}
SELECT * FROM Customers
```
Customers Query
:::
This also works for executable code cells that produce no output:
::: {#lst-assign}
```{r}
<- 1
x ```
Assignment in R
:::
However, if any output is produced, it is assumed the output should be the content of the cross-reference, and the code is lifted out and placed inline. For example, the code cell here produces output:
::: {#lst-assign-output}
```{r}
<- 1
x
x```
Assignment in R
:::
@lst-assign-output
When rendered the above results in output being the contents of the listing, with the code appearing before the listing:
If you need to reference both the code its output, use a combination of a display block and a code block with the code cell option echo: false
:
::: {#lst-assign-both}
```r
<- 1
x
x```
```{r}
#| echo: false
<- 1
x
x```
Assignment in R
:::
When the output is a figure or table, you can reference the code and the output individually by using code cell options, rather than the div syntax, as described in Cross-References for Executable Code Blocks.
Diagrams
To create a cross-references to a diagram using div syntax, treat it like a figure. For example, Figure 3 is created using:
::: {#fig-simple}
```{dot}
graph {
A -- B
}
```
This is a simple graphviz graph :::
If you would rather give diagrams a label and counter distinct from figures, consider defining Custom Cross-Reference Types.
Videos
To add a cross-reference to a video, use the cross-reference div syntax and treat it like a figure. For example,
::: {#fig-cern}
{{< video https://www.youtube.com/embed/wo9vZccmqwc >}}
The video "CERN: The Journey of Discovery"
:::
In @fig-cern...
Which renders as:
If you would rather give videos a label and counter distinct from figures, consider defining Custom Cross-Reference Types.
Subreferences
When your sub-content is either all figures or all tables there is abbreviated syntax, see the Cross References page for Subfigures and Subtables for details.
Cross-reference divs can be nested to create elements with subreferences. For example, the outer div here defines the fig-subrefs
reference along with the main caption, while the inner divs define fig-first
and fig-second
along with their respective captions:
:::: {#fig-subrefs}
::: {#fig-first}
CONTENT 1
First caption
:::
::: {#fig-second}
CONTENT 2
Second caption
:::
Main caption ::::
This renders as:
CONTENT 1
CONTENT 2
Both the main element and the sub elements can be referenced directly in the text, e.g.
@fig-subrefs, @fig-first, @fig-second
This renders as: Figure 4, Figure 4 (a), Figure 4 (b).
Combined with layout attributes, you can create complex layouts of mixed content where each element can be referenced. For example:
[1, 1], [1]]"}
:::: {#fig-complex layout="[
::: {#fig-elephant}
![](images/elephant.jpg)
An image file
:::
::: {#fig-scatterplot}
```{r}
#| echo: false
plot(1:10)
```
A computational figure
:::
::: {#fig-diagram}
```{dot}
//| fig-height: 2
digraph {
rankdir = "LR";
Transform -> Visualize
}
```
A diagram
:::
Example figure combining different types of content ::::
This renders as:
Conditional Content
The cross-reference div syntax combined with conditional content allows the content of your reference to vary by format. For example, you might want an interactive JavaScript based plot when the format is HTML, but otherwise produce a static plot:
::: {#fig-scatterplot}
:::: {.content-visible when-format="html"}
```{r}
# Code to produce JavaScript based plot
```
::::
:::: {.content-visible unless-format="html"}
```{r}
# Code to produce static plot
```
::::
Scatterplot
:::
@fig-scatterplot