What is ufo?
The ufo npm package provides utilities for URL formatting and normalization. It helps in parsing, resolving, and normalizing URLs, as well as providing utilities for handling query parameters.
What are ufo's main functionalities?
Parsing and normalizing URLs
This feature allows you to normalize URLs, which includes removing the default port for HTTP and HTTPS, decoding unnecessary percent-encoded characters, and removing duplicate slashes.
const { normalizeURL } = require('ufo');
const normalizedUrl = normalizeURL('http://example.com:80/path/');
Handling query parameters
This feature enables you to easily add query parameters to a URL, which can be useful for constructing URLs with dynamic query strings.
const { withQuery } = require('ufo');
const urlWithQuery = withQuery('http://example.com', { query: 'value' });
Joining URLs
This feature is used to concatenate URL parts safely, ensuring that there are no duplicate slashes and that the query string is properly appended.
const { joinURL } = require('ufo');
const fullUrl = joinURL('http://example.com', '/path', '?query=value');
Other packages similar to ufo
url-parse
The url-parse package offers similar URL parsing and manipulation functionalities. It provides a more detailed breakdown of the URL components and can be used in both Node.js and browser environments, whereas ufo is more focused on URL normalization and handling.
qs
The qs package is used for parsing and stringifying query strings. It goes into more depth for handling nested objects within query strings compared to ufo's simpler query parameter utilities.
urijs
URI.js is a URL mutation library that offers comprehensive URL manipulation capabilities. It has a fluent API for building and altering URL components, which might be more intuitive for some developers compared to ufo's more functional approach.
Install
Install using npm or yarn:
npm i ufo
yarn add ufo
Import:
const { normalizeURL, joinURL } = require('ufo')
import { normalizeURL, joinURL } from 'ufo'
import { parseURL } from 'https://unpkg.com/ufo/dist/index.mjs'
Notice: You may need to transpile package and add URL polyfill for legacy environments
Usage
normalizeURL
- Ensures URL is properly encoded
- Ensures pathname starts with slash
- Preserves protocol/host if provided
normalizeURL('test?query=123 123#hash, test')
normalizeURL('http://localhost:3000')
joinURL
joinURL('a', '/b', '/c')
resolveURL
joinURL('http://foo.com/foo?test=123#token', 'bar', 'baz')
withQuery
withQuery('/foo?page=a', { token: 'secret' })
getQuery
getQuery('http://foo.com/foo?test=123&unicode=%E5%A5%BD')
$URL
Implementing URL interface with some improvements:
- Supporting schemeless and hostless URLs
- Supporting relative URLs
- Preserving trailing-slash status
- Decoded and mutable classs properties (
protocol
, host
, auth
, pathname
, query
, hash
) - Consistent URL parser independent of environment
- Consistent encoding independent of environment
- Punycode support for host encoding
withTrailingSlash
Ensures url ends with a trailing slash
withTrailingSlash('/foo')
withoutTrailingSlash
Ensures url does not ends with a trailing slash
withoutTrailingSlash('/foo/')
cleanDoubleSlashes
Ensures url does not have double slash (except for protocol)
cleanDoubleSlashes('//foo//bar//')
cleanDoubleSlashes('http://example.com/analyze//http://localhost:3000//')
isSamePath
Check two paths are equal or not. Trailing slash and encoding are normalized before comparation.
isSamePath('/foo', '/foo/')
isRelative
Check if a path starts with ./
or ../
.
isRelative('./foo')
License
MIT
Special thanks to Eduardo San Martin Morote (posva) for encoding utlities