鄙人初步学习nodejs,目前在读《nodejs入门》这一本书,书很小,但是让我知道了如何用nodejs创建一个简单的小项目。例如如何创建一个服务器啦,例如http.createServer,还有根据不同的请求路径来设置路由选择啦,模块引入,创建模块啦,巴拉巴拉的东西。
现在还没有看完这本书,看完了再来写读后感吧。
今天主要记录的是关于nodejs里面的一个简单的模块,url模块。这个url的模块要使用的话需要先引入。若只是在命令行里比如cmd或git bash 等使用url这个模块的话,是不需要require进来的。直接使用便可。(我也不知道为啥不用require)
const这个关键字是ES6里面定义的常量,不可改变。
1 const url = require("url");
url一共提供了三个方法,分别是url.parse(); url.format(); url.resolve();
1 url.parse(urlString,boolean,boolean)
parse这个方法可以将一个url的字符串解析并返回一个url的对象
参数:urlString指传入一个url地址的字符串
第二个参数(可省)传入一个布尔值,默认为false,为true时,返回的url对象中,query的属性为一个对象。
第三个参数(可省)传入一个布尔值,默认为false,为true时,额,我也不知道有什么不同,可以去看看API。
例子1,url.parse只传一个参数的情况。
1 url.parse("http://user:pass@host.com:8080/p/a/t/h?query=string#hash");
2 /*
3 返回值:
4 {
5 protocol: 'http:',
6 slashes: true,
7 auth: 'user:pass',
8 host: 'host.com:8080',
9 port: '8080',
10 hostname: 'host.com',
11 hash: '#hash',
12 search: '?query=string',
13 query: 'query=string',
14 pathname: '/p/a/t/h',
15 path: '/p/a/t/h?query=string',
16 href: 'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
17 }
18 没有设置第二个参数为true时,query属性为一个字符串类型
19 */
例子2,url.parse第二个参数为true的情况
1 url.parse("http://user:pass@host.com:8080/p/a/t/h?query=string#hash",true);
2 /*
3 返回值:
4 {
5 protocol: 'http:',
6 slashes: true,
7 auth: 'user:pass',
8 host: 'host.com:8080',
9 port: '8080',
10 hostname: 'host.com',
11 hash: '#hash',
12 search: '?query=string',
13 query: { query: 'string' },
14 pathname: '/p/a/t/h',
15 path: '/p/a/t/h?query=string',
16 href: 'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
17 }
18 返回的url对象中,query属性为一个对象
19 */
2 url.format(urlObj)
format这个方法是将传入的url对象编程一个url字符串并返回
参数:urlObj指一个url对象
例子3,url.format
url.format({
protocol:"http:",
host:"182.163.0:60",
port:"60"
});
/*
返回值:
'http://182.163.0:60'
*/
3 url.resolve(from,to)
resolve这个方法返回一个格式为"from/to"的字符串,在宝宝看来是对传入的两个参数用"/"符号进行拼接,并返回
例子4,url.resolve
url.resolve("http://whitemu.com","gulu");
/*
返回值:
'http://whitemu.com/gulu'
*/
结束语:
好啦,对于url这个模块的总结就那么多啦,若有什么理解错误的地方还需要指正,谢谢。