源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Node.js学习之地址解析模块URL的使用详解

  • 时间:2022-12-18 09:24 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Node.js学习之地址解析模块URL的使用详解
[b]前言[/b] 本文主要给大家介绍了关于Node.js地址解析模块URL使用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 [b]url结构化/模块化/路径解析[/b] [list] [*]结构化:[code]url.parse(urlString[, parseQueryString[, slashesDenoteHost]])[/code][/*] [*]模块化:[code]url.format(urlObject)[/code][/*] [*]路径解析:[code]url.resolve(from, to)[/code][/*] [/list] 一个URL字符串是一个结构化的字符串包含多个有意义的组件。在解析时,返回一个URL对象包含每一个组件的属性。 官方手册上面的一张图是这样子的: [img]http://files.jb51.net/file_images/article/201709/2017928113456779.png?201782811356[/img] 这张图解释了一个url结构化成哪些部分,哪些部分又包含哪些部分 protocol: 请求协议 host: URL主机名已全部转换成小写, 包括端口信息 auth:URL中身份验证信息部分 hostname:主机的主机名部分, 已转换成小写 port: 主机的端口号部分 pathname: URL的路径部分,位于主机名之后请求查询之前 search: URL 的“查询字符串”部分,包括开头的问号。 path: pathname 和 search 连在一起。 query: 查询字符串中的参数部分(问号后面部分字符串),或者使用 querystring.parse() 解析后返回的对象。   hash: URL 的 “#” 后面部分(包括 # 符号) [b]url结构化[/b] 将一个url地址结构化成为拥有上图属性的url对象。url.parse第二个和第三个参数默认为false。 [list] [*]第二个参数决定query属性值是字符串还是对象[/*] [*]第三个参数如果为true,//后的第一个令牌文字字符串和下一个/之间的文字字符串将被解释为主机[/*] [/list] 例子如下
const url = require("url");
var urlstr = "http://localhost:8888/bb?name=bigbear&memo=helloworld&memo=helloC";
var urlobj = url.parse(urlstr); 
console.log(urlobj);
/*
Url {
 protocol: 'http:',
 slashes: true,
 auth: null,
 host: 'localhost:8888',
 port: '8888',
 hostname: 'localhost',
 hash: null,
 search: '?name=bigbear&memo=helloworld&memo=helloC',
 query: 'name=bigbear&memo=helloworld&memo=helloC',
 pathname: '/bb',
 path: '/bb?name=bigbear&memo=helloworld&memo=helloC',
 href: 'http://localhost:8888/bb?name=bigbear&memo=helloworld&memo=helloC' }
*/
第二个参数为true时
query: { name: ‘bigbear', memo: [ ‘helloworld', ‘helloC' ] },
例子如下:
const url = require("url");
var urlstr = "http://localhost:8888/bb?name=bigbear&memo=helloworld&memo=helloC";
console.log(
 url.parse(urlstr, true)
)
/*
Url {
 protocol: 'http:',
 slashes: true,
 auth: null,
 host: 'localhost:8888',
 port: '8888',
 hostname: 'localhost',
 hash: null,
 search: '?name=bigbear&memo=helloworld&memo=helloC',
 query: { name: 'bigbear', memo: [ 'helloworld', 'helloC' ] },
 pathname: '/bb',
 path: '/bb?name=bigbear&memo=helloworld&memo=helloC',
 href: 'http://localhost:8888/bb?name=bigbear&memo=helloworld&memo=helloC' }
*/
第三个参数对比 例子如下:
const url = require("url");
var urlstr = "//foo/bar ";
console.log(
 url.parse(urlstr, true,true)
)
/*
 输出:Url {
 protocol: null,
 slashes: true,
 auth: null,
 host: 'foo',
 port: null,
 hostname: 'foo',
 hash: null,
 search: '',
 query: {},
 pathname: '/bar',
 path: '/bar',
 href: '//foo/bar' }
*/


const url = require("url");
var urlstr = "//foo/bar ";
console.log(
 url.parse(urlstr)
)
/*
输出:
Url {
 protocol: null,
 slashes: null,
 auth: null,
 host: null,
 port: null,
 hostname: null,
 hash: null,
 search: null,
 query: null,
 pathname: '//foo/bar',
 path: '//foo/bar',
 href: '//foo/bar' }
*/
[b]url模块化[/b] 将一个url对象转换成一个url字符串,url对象中的属性为[code]url.parse()[/code]产生的对象的属性。 [code]url.parse()[/code]和[code]url.format()[/code]互为逆操作。 例子如下:
const url = require("url");
var Urlobj = {
 protocol: 'http:',
 slashes: true,
 auth: null,
 host: 'localhost:8888',
 port: '8888',
 hostname: 'localhost',
 hash: null,
 search: '?name=bigbear&memo=helloworld&memo=helloC',
 query: { name: 'bigbear', memo: [ 'helloworld', 'helloC' ] },
 pathname: '/bb',
 path: '/bb?name=bigbear&memo=helloworld&memo=helloC',
 }
console.log(
 url.format(Urlobj)
)
//输出:http://localhost:8888/bb?name=bigbear&memo=helloworld&memo=helloC
[b]路径解析:url.resolve(from, to)[/b] [code]url.resolve()[/code]方法解决了目标URL相对于基本URL的方式类似于Web浏览器解决锚标记href。 官方手册例子:
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'
[b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部