40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# isurl [![NPM Version][npm-image]][npm-url] [![Build Status][travis-image]][travis-url]
 | 
						|
 | 
						|
> Checks whether a value is a WHATWG [`URL`](https://developer.mozilla.org/en/docs/Web/API/URL).
 | 
						|
 | 
						|
 | 
						|
Works cross-realm/iframe and despite @@toStringTag.
 | 
						|
 | 
						|
 | 
						|
## Installation
 | 
						|
 | 
						|
[Node.js](http://nodejs.org/) `>= 4` is required. To install, type this at the command line:
 | 
						|
```shell
 | 
						|
npm install isurl
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
## Usage
 | 
						|
 | 
						|
```js
 | 
						|
const isURL = require('isurl');
 | 
						|
 | 
						|
isURL('http://domain/');  //-> false
 | 
						|
isURL(new URL('http://domain/'));  //-> true
 | 
						|
```
 | 
						|
 | 
						|
Optionally, acceptance can be extended to incomplete `URL` implementations that lack `searchParams` (which are common in many modern web browsers):
 | 
						|
```js
 | 
						|
const url = new URL('http://domain/?query');
 | 
						|
 | 
						|
console.log(url.searchParams);  //-> undefined
 | 
						|
 | 
						|
isURL.lenient(url);  //-> true
 | 
						|
```
 | 
						|
 | 
						|
 | 
						|
[npm-image]: https://img.shields.io/npm/v/isurl.svg
 | 
						|
[npm-url]: https://npmjs.org/package/isurl
 | 
						|
[travis-image]: https://img.shields.io/travis/stevenvachon/isurl.svg
 | 
						|
[travis-url]: https://travis-ci.org/stevenvachon/isurl
 |