前言
一个完整的url分几部分呢,如下面这个网址:
http://www.tmooc.cn:80/detail.html?lid=5
由遵循的协议+域名+端口号+所要请求的服务器上的哪个文件+传递给服务器的数据组成。
下面我们就来具体学习一下关于url的知识。
一、什么是url模块
url 模块提供用于网址处理
和解析
的实用工具。 可以使用两种以下方式访问它:
//第一种
import url from 'url';
//第二种
const url = require('url');
二、网址字符串与网址对象
网址字符串是包含多个有意义组件的结构化字符串
。 解析时,将返回包含每个组件的属性的网址对象
。
现在,url模块提供了两种API来处理网址,一种是旧版,由url.parse()返回的对象的属性,一种是新版,实现了与Web浏览器使用的相同的WHATWG网址标准。
以网址’https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash’为例,我们在Node.js官网上可以找到新旧两版的区别。
在网址 ‘https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash’ 上方显示的是由旧版 url.parse() 返回的对象的属性。 下方则是 WHATWG URL 对象的属性。
WHATWG 网址的 origin 属性包括 protocol 和 host,但不包括 username 或 password。
1、使用url.parse()解析网址字符串
//引入url模块
const url = require('url');
//处理和解析URL
var str = 'https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash'
//把URL解析为对象
var obj = url.parse(str);
console.log(obj)
2、使用WHATWG API解析网址字符串
new URL(input[, base]);
input
< string > 要解析的绝对或相对的输入网址。 如果 input 是相对的,则需要 base。 如果 input 是绝对的,则忽略 base。
base
< string > | < URL > 如果 input 不是绝对的,则为要解析的基本网址。
通过相对于 base 解析 input 来创建新的 URL 对象。 如果 base 作为字符串传入,则其将被解析为等效于 new URL(base)。
base的用法举例如下:
const myURL = new URL('./foo','https://example.org/');
console.log(myURL.href)
//引入url模块
const url = require('url');
const myurl = new URL('https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash');
console.log(myurl);
其中:
protocol:协议
hosthome:主机名,域名(或者ip地址)
port:端口号
pathname:请求的文件路径名称
query:查询字符串
三、把对象格式化为URL(旧版方法)
url.format(URL[, options])
URL
< URL > WHATWG 网址对象
options
< Object >
返回
< string >
返回 WHATWG 网址对象的网址 S