@thwack/resolve
TypeScript icon, indicating that this package has built-in type declarations

1.0.0 • Public • Published

@thwack/resolve

What is it?

  • Functionally equivalent to new URL(url, base).href
  • Works on browsers, NodeJS, and React Native
  • Has loads of tests that use URL as its expected results

Why?

I needed to resolve a URL against a base when writing Thwack. Initially I used new URL(url, base).href, but found that it failed when running on React Native as it's implimenation of URL sucks (to put it mildly).

I initially imported react-native-url-polyfill but it's 41k, which is more than 10x Thwack itself!

So I set out to write my own and share it with the world.

Installation

$ npm i @thwack/resolve

or

$ yarn add @thwack/resolve

The RegEx

It is based on the RegEx in the RFC for Uniform Resource Identifier (i.e. the URL syntax for the internet)

^(([^:\/?#]+):)?(\/\/([^\/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?

see https://tools.ietf.org/html/rfc3986#appendix-B

The RegEx returns:

$1 = http:
$2 = http                //protocol
$3 = //www.example.com
$4 = www.example.com     //domain
$5 = /foo/bar/ or foo    //path
$6 = ?a=b                //search
$7 = a=b
$8 = #hash               //hash
$9 = hash

Note 1: all but $5 will be undefined if missing. $5 will be ""

Note 2: $5 will be "undefined" (a string) if uri is undefined

Note 3: $4 will be undefined if missing or "" if present but blank

License

Licensed under MIT

Package Sidebar

Install

npm i @thwack/resolve

Weekly Downloads

88

Version

1.0.0

License

MIT

Unpacked Size

22.1 kB

Total Files

11

Last publish

Collaborators

  • donavon