# jsx-a11y/anchor-ambiguous-text 🚫 This rule is _disabled_ in the ☑️ `recommended` config. Enforces `` values are not exact matches for the phrases "click here", "here", "link", "a link", or "learn more". Screenreaders announce tags as links/interactive, but rely on values for context. Ambiguous anchor descriptions do not provide sufficient context for users. ## Rule options This rule takes one optional object argument with the parameter `words`. ```json { "rules": { "jsx-a11y/anchor-ambiguous-text": [2, { "words": ["click this"], }], } } ``` The `words` option allows users to modify the strings that can be checked for in the anchor text. Useful for specifying other words in other languages. The default value is set by `DEFAULT_AMBIGUOUS_WORDS`: ```js const DEFAULT_AMBIGUOUS_WORDS = ['click here', 'here', 'link', 'a link', 'learn more']; ``` The logic to calculate the inner text of an anchor is as follows: - if an element has the `aria-label` property, its value is used instead of the inner text - if an element has `aria-hidden="true`, it is skipped over - if an element is `` or configured to be interpreted like one, its `alt` value is used as its inner text Note that this rule still disallows ambiguous `aria-label` or `alt` values. Note that this rule is case-insensitive, trims whitespace, and ignores certain punctuation (`[,.?¿!‽¡;:]`). It only looks for **exact matches**. ### Succeed ```jsx read this tutorial // passes since it is not one of the disallowed words ${here} // this is valid since 'here' is a variable name click here // the aria-label supersedes the inner text ``` ### Fail ```jsx here HERE link click here learn more learn more. learn more, learn more? learn more! learn more: learn more; a link a link click here // goes through element children a link a link // skips over elements with aria-hidden=true learn moresomething // the aria-label here is inaccessible // the alt tag is still ambiguous click here // the alt tag is only parsed on img ``` ## Accessibility guidelines Ensure anchor tags describe the content of the link, opposed to simply describing them as a link. Compare ```jsx
click here to read a tutorial by Foo Bar
``` which can be more concise and accessible with ```jsx ``` ### Resources 1. [WebAIM, Hyperlinks](https://webaim.org/techniques/hypertext/) 2. [Deque University, Link Checklist - 'Avoid "link" (or similar) in the link text'](https://dequeuniversity.com/checklists/web/links)