//// Included in: - user-manual: Defining an Anchor //// An anchor (aka ID) can be defined almost anywhere in the document, including on section title, on a discrete heading, on a paragraph, on an image, on a delimited block, on an inline phrase, and so forth. The anchor is declared by enclosing a _valid_ XML Name in double square brackets (e.g., `+[[idname]]+`) or using the shorthand ID syntax (e.g., `[#idname]`) at the start of an attribute list. The double square bracket form requires the ID to start with a letter, an underscore, or a colon, ensuring the ID is portable. According to the https://www.w3.org/TR/REC-xml/#NT-Name[XML Name] rules, a portable ID may not begin with a number, even though a number is allowed elsewhere in the name. The shorthand form in an attribute list does not impose this restriction. If you want to reference a block element, all you need to do is assign an ID to that block. You can enclose the ID in double square brackets: .Assigning an ID to a paragraph [source] ---- include::ex-xref.adoc[tag=block-id-brackets] ---- or use the shorthand ID syntax: .Assigning an ID to a paragraph using shorthand syntax [source] ---- include::ex-xref.adoc[tag=block-id-shorthand] ---- You can also define an anchor anywhere in content that receives normal substitutions (specifically the macro substitution). You can enclose the ID in double square brackets: .Defining an inline anchor [source] ---- include::ex-xref.adoc[tag=anchor-brackets] ---- or using the shorthand ID syntax. .Defining an inline anchor using shorthand syntax [source] ---- include::ex-xref.adoc[tag=anchor-shorthand] ---- In addition to being able to define anchors on sections and blocks, anchors can be defined inline where ever you can type normal text (anchors are a macro substitution). The anchors in the text get replaced with invisible anchor points in the output. For example, you would not put an anchor in front of a list item: .Wrong position for an anchor ID in front of a list item. [source] ---- include::ex-xref.adoc[tag=anchor-wrong] ---- Instead, you would put it at the very start of the text of the list item: .Defining an inline anchor on a list item [source] ---- include::ex-xref.adoc[tag=anchor-list] ---- Here's how you can define the ID for a section using an inline anchor: .Defining the ID of a section using an inline anchor [source] ---- include::ex-xref.adoc[tag=anchor-header] ---- To add additional anchors to a section, place them in front of the title. .Adding additional anchors to a section [source] ---- include::ex-xref.adoc[tag=anchor-header-extra] ---- CAUTION: If you add additional anchors to a section title, make sure you also assign an explicit ID to that section. Otherwise, the anchor tag gets caught up in the generated ID. See {issue-ref}/840[#840] for details. Remember that inline anchors are discovered where ever the macro substitution is applied (e.g., paragraph text). If text content doesn't belong somewhere, neither does an inline anchor point. // TODO introduce a subsection here It's possible to customize the text that will be used in the cross reference link (called `xreflabel`). If not defined, Asciidoctor does it best to find suitable text (the solution differs from case to case). In case of an image, the image caption will be used. In case of a section header, the text of the section's title will be used. To define the `xreflabel`, add it in the anchor definition right after the ID (separated by a comma). .An anchor ID with a defined xreflabel. The caption will not be used as link text. [source] ---- include::ex-xref.adoc[tag=anchor-xreflabel] ---- Instead of the bracket form, you can use the macro `anchor` to achieve the same goal. .Setting an anchor ID using the macro form [source] ---- include::ex-xref.adoc[tag=anchor-macro] ----