link
Element
Links to a URL or a location in the document.
By default, links do not look any different from normal text. However, you can easily apply a style of your choice with a show rule.
Example
#show link: underline
https://example.com \
#link("https://example.com") \
#link("https://example.com")[
See example.com
]
data:image/s3,"s3://crabby-images/5c606/5c60683cc260426fbc9654b28f4bcb7a742d6e7e" alt="Preview"
Hyphenation
If you enable hyphenation or justification, by default, it will not apply to links to prevent unwanted hyphenation in URLs. You can opt out of this default via show link: set text(hyphenate: true)
.
Syntax
This function also has dedicated syntax: Text that starts with http://
or https://
is automatically turned into a link.
Parameters
dest
The destination the link points to.
-
To link to web pages,
dest
should be a valid URL string. If the URL is in themailto:
ortel:
scheme and thebody
parameter is omitted, the email address or phone number will be the link's body, without the scheme. -
To link to another part of the document,
dest
can take one of three forms:-
A label attached to an element. If you also want automatic text for the link based on the element, consider using a reference instead.
-
A
location
(typically retrieved fromhere
,locate
orquery
). -
A dictionary with a
page
key of type integer andx
andy
coordinates of type length. Pages are counted from one, and the coordinates are relative to the page's top left corner.
-
View example
= Introduction <intro>
#link("mailto:hello@typst.app") \
#link(<intro>)[Go to intro] \
#link((page: 1, x: 0pt, y: 0pt))[
Go to top
]
data:image/s3,"s3://crabby-images/fb886/fb8868ee2fd461f872be55f7c0b58b2d6d662af8" alt="Preview"
body
The content that should become a link.
If dest
is an URL string, the parameter can be omitted. In this case, the URL will be shown as the link.