- 第1节:Node.js 教程
- 第2节:Node.js 安装配置
- 第3节:Node.js 创建第一个应用
- 第4节:Node.js NPM 使用介绍
- 第5节:Node.js REPL(交互式解释器)
- 第6节:Node.js 回调函数
- 第7节:Node.js 事件循环
- 第8节:Node.js EventEmitter
- 第9节:Node.js Buffer(缓冲区)
- 第10节:Node.js Stream(流)
- 第11节:Node.js 模块系统
- 第12节:Node.js 函数
- 第13节:Node.js 路由
- 第14节:Node.js 全局对象
- 第15节:Node.js 常用工具util
- 第16节:Node.js 文件系统
- 第17节:Node.js GET/POST请求
- 第18节:Node.js 工具模块
- 第19节:Node.js Web 模块
- 第20节:Node.js Express 框架
- 第21节:Node.js RESTful API
- 第22节:Node.js 多进程
- 第23节:Node.js JXcore 打包
- 第24节:Node.js 连接 MySQL
- 第25节:Node.js 连接 MongoDB
- 第26节:关于 Node.js
- 第27节:Node.js 示例
- 第28节:Node.js 断言测试
- 第29节:Node.js 事件
- 第30节:Node.js Punycode
- 第31节:Node.js Buffer
- 第32节:Node.js 文件系统
- 第33节:Node.js Query Strings
- 第34节:Node.js C/C++ 插件
- 第35节:Node.js 逐行读取
- 第36节:Node.js 全局对象
- 第37节:Node.js 子进程
- 第38节:Node.js REPL
- 第39节:Node.js HTTP
- 第40节:Node.js 集群
- 第41节:Node.js Smalloc
- 第42节:Node.js HTTPS
- 第43节:Node.js 控制台
- 第44节:Node.js 模块
- 第45节:Node.js 加密
- 第46节:Node.js 流
- 第47节:Node.js 网络
- 第48节:Node.js 调试器
- 第49节:Node.js 字符串解码器
- 第50节:Node.js 系统
- 第51节:Node.js DNS
- 第52节:Node.js 定时器
- 第53节:Node.js 路径
- 第54节:Node.js 域
- 第55节:Node.js TLS/SSL
- 第56节:Node.js 进程
- 第57节:Node.js TTY
- 第58节:Node.js UDP/Datagram
- 第59节:Node.js URL
- 第60节:Node.js 实用工具
- 第61节:Node.js 虚拟机
- 第62节:Node.js ZLIB
Node.js URL
稳定性: 3 - 稳定
Node.js的URL模块提供了用于分析和解析URL的实用程序。可以调用require('url')
来访问它:
const url = require('url');
解析URL对象有以下内容,依赖于他们是否在URL字符串里存在。任何不在URL字符串里的部分,都不会出现在解析对象里。例子如下:
'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
href
:准备解析的完整的URL,包含协议和主机(小写)。例子:
'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
protocol
: 请求协议,小写。例子:
'http:'
slashes
: 协议要求的斜杠(冒号后)例子:true或false
host
: 完整的URL小写主机部分,包含端口信息。例子:
'host.com:8080'
auth
: url中的验证信息。例子:
'user:pass'
hostname
: 域名中的小写主机名例子:
'host.com'
port
: 主机的端口号例子:
'8080'
pathname
: URL中的路径部分,在主机名后,查询字符前,包含第一个斜杠。例子:
'/p/a/t/h'
search
: URL中得查询字符串,包含开头的问号例子:
'?query=string'
path
:pathname
和search
连在一起例子:
'/p/a/t/h?query=string'
query
: 查询字符串中得参数部分,或者使用querystring.parse()解析后返回的对象。例子:
'query=string'
或者{'query':'string'}
hash
: URL的“#”后面部分(包括 # 符号)例子:
'#hash'
URL模块提供了以下方法:
url.parse(urlStr[, parseQueryString][, slashesDenoteHost])
输入URL字符串,返回一个对象。
第二个参数为true
时,使用querystring
来解析查询字符串。如果为true
,query
属性将会一直赋值为对象,并且search
属性将会一直是字符串(可能为空)。默认为false
。
第三个参数为true
,把//foo/bar
当做{ host: 'foo', pathname: '/bar' }
,而不是{ pathname: '//foo/bar' }
。默认为false
。
url.format(urlObj)
输入一个解析过的URL对象,返回格式化过的字符串。
格式化的工作流程:
href
会被忽略protocol
无论是否有末尾的 : (冒号),会同样的处理http
,https
,ftp
,gopher
,file
协议会被添加后缀://
mailto
,xmpp
,aim
,sftp
,foo
等协议添加后缀:
slashes
如果协议需要://
,设置为true。- 仅需对之前列出的没有斜杠的协议,比如议
mongodb://localhost:8000/
- 仅需对之前列出的没有斜杠的协议,比如议
auth
如果出现将会使用.hostname
仅在缺少host
时使用port
仅在缺少host
时使用host
用来替换hostname
和port
pathname
无论结尾是否有“/”将会同样处理search
将会替 query属性- 无论前面是否有“/”将会同样处理
query
(对象;参见querystring
) 如果没有search,将会使用hash
无论前面是否有#,都会同样处理
url.resolve(from, to)
给一个基础URL,href URL,如同浏览器一样的解析它们可以带上锚点,例如:
url.resolve('/one/two/three', 'four') // '/one/two/four'
url.resolve('http://example.com/', '/one') // 'http://example.com/one'
url.resolve('http://example.com/one', '/two') // 'http://example.com/two'