41 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
| # @jridgewell/resolve-uri
 | |
| 
 | |
| > Resolve a URI relative to an optional base URI
 | |
| 
 | |
| Resolve any combination of absolute URIs, protocol-realtive URIs, absolute paths, or relative paths.
 | |
| 
 | |
| ## Installation
 | |
| 
 | |
| ```sh
 | |
| npm install @jridgewell/resolve-uri
 | |
| ```
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| ```typescript
 | |
| function resolve(input: string, base?: string): string;
 | |
| ```
 | |
| 
 | |
| ```js
 | |
| import resolve from '@jridgewell/resolve-uri';
 | |
| 
 | |
| resolve('foo', 'https://example.com'); // => 'https://example.com/foo'
 | |
| ```
 | |
| 
 | |
| | Input                 | Base                    | Resolution                     | Explanation                                                  |
 | |
| |-----------------------|-------------------------|--------------------------------|--------------------------------------------------------------|
 | |
| | `https://example.com` | _any_                   | `https://example.com/`         | Input is normalized only                                     |
 | |
| | `//example.com`       | `https://base.com/`     | `https://example.com/`         | Input inherits the base's protocol                           |
 | |
| | `//example.com`       | _rest_                  | `//example.com/`               | Input is normalized only                                     |
 | |
| | `/example`            | `https://base.com/`     | `https://base.com/example`     | Input inherits the base's origin                             |
 | |
| | `/example`            | `//base.com/`           | `//base.com/example`           | Input inherits the base's host and remains protocol relative |
 | |
| | `/example`            | _rest_                  | `/example`                     | Input is normalized only                                     |
 | |
| | `example`             | `https://base.com/dir/` | `https://base.com/dir/example` | Input is joined with the base                                |
 | |
| | `example`             | `https://base.com/file` | `https://base.com/example`     | Input is joined with the base without its file               |
 | |
| | `example`             | `//base.com/dir/`       | `//base.com/dir/example`       | Input is joined with the base's last directory               |
 | |
| | `example`             | `//base.com/file`       | `//base.com/example`           | Input is joined with the base without its file               |
 | |
| | `example`             | `/base/dir/`            | `/base/dir/example`            | Input is joined with the base's last directory               |
 | |
| | `example`             | `/base/file`            | `/base/example`                | Input is joined with the base without its file               |
 | |
| | `example`             | `base/dir/`             | `base/dir/example`             | Input is joined with the base's last directory               |
 | |
| | `example`             | `base/file`             | `base/example`                 | Input is joined with the base without its file               |
 |