Link
The Link
component allows you to customize anchor tags with theme colors and typography styles.
Introduction
The Link
component represents the HTML <a>
element.
It accepts the same props as the Typography
component, as well as the system props.
<Link />
Playground
Component
After installation, you can start building with this component using the following basic elements:
<span class="token keyword">import</span> Link <span class="token keyword">from</span> <span class="token string">'@mui/joy/Link'</span><span class="token punctuation">;</span>
<span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token keyword">function</span> <span class="token function">MyApp</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
<span class="token keyword">return</span> <span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span>Hello world<span class="token operator">!</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>
As a button
To use the Link
as a button, assign the button
value to the component
prop.
It's useful doing it in two main situations:
- The link doesn't have a meaningful href.
- The design looks more a link rather than a button.
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Link</span></span>
<span class="token attr-name">component</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>button<span class="token punctuation">"</span></span>
<span class="token attr-name">onClick</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token operator">=></span> <span class="token punctuation">{</span>
<span class="token comment">// ...process something</span>
<span class="token punctuation">}</span><span class="token punctuation">}</span></span>
<span class="token punctuation">></span></span>
Do something
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span>
With a typography
Link
can be used as a child of the Typography
component.
In that case, the link component will inherit the typographic level scale from its typography parent, unless a value for the level
prop is specified.
Heading
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore Magna Aliqua. Maecenas sed enim ut sem viverra aliquet eget.
With a card
Using the Link
component as a card title, with the overlay
prop, ensures proper accessibility when the whole card is clickable.
Components that spark joy!
Click the and TAB to test the focus
Security
When using target="_blank"
with links, it's recommended to always set rel="noopener"
or rel="noreferrer"
when linking to a third-party content.
rel="noopener"
prevents the new page from being able to access thewindow.opener
property and ensures it runs in a separate process. Without this, the target page can potentially redirect your page to a malicious URL.rel="noreferrer"
has the same effect, but also prevents the Referer header from being sent to a new page. ⚠️ Removing the referrer header will affect analytics.
Accessibility
Here are a few tips for ensuring an accessible link component, based on WAI-ARIA.
- Copywriting: Avoid generic words as call to action, such as "click here" or "go to". Instead, use descriptive texts.
- Design: For a good user experience, links should stand out from the text on the page.
Keeping the default
underline="always"
behavior is a safe bet. - Href: If a link doesn't have a meaningful href, it should be rendered using a
<button>
element.
Third-party routing library
Here's how you can use the link component with libraries that also provide their version of it.
Next.js
Here is an example with the Link component of Next.js:
<span class="token keyword">import</span> NextLink <span class="token keyword">from</span> <span class="token string">'next/link'</span><span class="token punctuation">;</span>
<span class="token keyword">import</span> Link <span class="token keyword">from</span> <span class="token string">'@mui/joy/Link'</span><span class="token punctuation">;</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">NextLink</span></span> <span class="token attr-name">href</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>/docs<span class="token punctuation">"</span></span> <span class="token attr-name">passHref</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span>Read doc<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">NextLink</span></span><span class="token punctuation">></span></span><span class="token punctuation">;</span>
React Router
Here is an example with the Link component of React Router:
<span class="token keyword">import</span> <span class="token punctuation">{</span> Link <span class="token keyword">as</span> RouterLink <span class="token punctuation">}</span> <span class="token keyword">from</span> <span class="token string">'react-router-dom'</span><span class="token punctuation">;</span>
<span class="token keyword">import</span> Link <span class="token keyword">from</span> <span class="token string">'@mui/joy/Link'</span><span class="token punctuation">;</span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Link</span></span> <span class="token attr-name">component</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span>RouterLink<span class="token punctuation">}</span></span> <span class="token attr-name">to</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>/docs<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
Read doc
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">Link</span></span><span class="token punctuation">></span></span><span class="token punctuation">;</span>
Common examples
Examples showcasing how to compose designs with the Link
component and others as decorators.