URL & URLSearchParams
20 Jan, 2023
👋 FYI, this note is over 6 months old. Some of the content may be out of date.
On this page
URL Jump to heading
Docs: http://developer.mozilla.org/en-US/docs/Web/API/URL
const url = new URL('https://mysite.com/login?user=zander&page=news#hello')
url.hostname // mysite.com
url.pathname // /login
url.href // https://mysite.com/login?user=zander&page=news#hello
url.origin // https://mysite.com
url.search // ?user=zander&page=news
url.hash // #hello
URLSearchParams Jump to heading
Docs: http://developer.mozilla.org/en-US/docs/Web/API/URLSearchParams/URLSearchParams
// example.com?much=wow
const params = new URLSearchParams(
'https://mysite.com/login?user=zander&page=news#hello'
)
params.has('user') // true
params.get('user') // 'zander'
params.set('page', 'code')
params.toString() // user=zander&page=code
for ([key, value] of params) {
// ...
}
params.delete('page')
params.toString() // user=zander
To convert a url with search params to an object: Jump to heading
// one liner
const params = Object.fromEntries(
new URLSearchParams(
new URL('https://mysite.com/login?user=zander&page=news#hello').search
)
)
// multi-line
const url = new URL('https://mysite.com/login?user=zander&page=news#hello')
const urlParams = new URLSearchParams(url.search)
const params = Object.fromEntries(urlParams)
Polyfill: https://github.com/ungap/url-search-params#readme
Use proper-url-join
to construct a url
Jump to heading
I use this package on nearly every project to normalise urls
https://github.com/moxystudio/js-proper-url-join
import urlJoin from 'proper-url-join'
urlJoin('foo', 'bar') // /foo/bar
urlJoin('/foo/', '/bar/') // /foo/bar
urlJoin('foo', '', 'bar') // /foo/bar
urlJoin('foo', undefined, 'bar') // /foo/bar
urlJoin('foo', null, 'bar') // /foo/bar
// With leading & trailing slash options
urlJoin('foo', 'bar', { leadingSlash: false }) // foo/bar
urlJoin('foo', 'bar', { trailingSlash: true }) // /foo/bar/
urlJoin('foo', 'bar', { leadingSlash: false, trailingSlash: true }) // foo/bar/
// Absolute URLs
urlJoin('http://google.com', 'foo') // http://google.com/foo
// Protocol relative URLs
urlJoin('//google.com', 'foo', { protocolRelative: true }) // //google.com/foo
// With query string as an url part
urlJoin('foo', 'bar?queryString') // /foo/bar?queryString
urlJoin('foo', 'bar?queryString', { trailingSlash: true }) // /foo/bar/?queryString
// With query string as an object
urlJoin('foo', { query: { biz: 'buz', foo: 'bar' } }) // /foo?biz=buz&foo=bar
// With both query string as an url part and an object
urlJoin('foo', 'bar?queryString', { query: { biz: 'buz', foo: 'bar' } }) // /foo/bar?biz=buz&foo=bar&queryString
← Back home