linkify-urls
Linkify URLs in a string
Install
npm install linkify-urls
Usage
import {linkifyUrlsToHtml, linkifyUrlsToDom} from 'linkify-urls';
linkifyUrlsToHtml('See https://sindresorhus.com', {
attributes: {
class: 'unicorn',
one: 1,
foo: true,
multiple: [
'a',
'b'
]
}
});
const fragment = linkifyUrlsToDom('See https://sindresorhus.com', {
attributes: {
class: 'unicorn',
}
});
document.body.appendChild(fragment);
API
linkifyUrlsToHtml(string, options?)
Returns an HTML string like 'Visit <a href="https://example.com">https://example.com</a>'.
string
Type: string
A string with URLs to linkify.
options
Type: object
attributes
Type: object
HTML attributes to add to the link.
Security note: For external links, consider adding rel: 'noreferrer' to prevent the linked page from accessing window.opener and to avoid sending referrer information. This helps protect against reverse tabnabbing attacks and preserves user privacy:
linkifyUrlsToHtml('Visit https://example.com', {
attributes: {
rel: 'noreferrer',
target: '_blank'
}
});
value
Type: string | Function
Default: The URL
Set a custom HTML value for the link.
If it's a function, it will receive the URL as a string:
linkifyUrlsToHtml('See https://sindresorhus.com/foo', {
value: url => new URL(url).pathname
});
linkifyUrlsToDom(string, options?)
Returns a DocumentFragment ready to be appended in a DOM safely, like DocumentFragment(TextNode('Visit '), HTMLAnchorElement('https://example.com')).
This type only works in the browser.
LinkifyUrls (React component)
React component that linkifies URLs in its children.
import React from 'react';
import {LinkifyUrls} from 'linkify-urls/react';
<LinkifyUrls attributes={{target: '_blank', class: 'link'}}>
Check out https://example.com for more info.
</LinkifyUrls>
This approach is safer and more performant than using dangerouslySetInnerHTML.
options
See options above.
Related