Node.js v8.x 中文文档
目录
querystring - 查询字符串#
querystring
模块提供了一些实用函数,用于解析与格式化 URL 查询字符串。
使用以下方法引入:
const querystring = require('querystring');
querystring.escape(str)#
str
<string>
对给定的 str
进行 URL 编码。
该方法是提供给 querystring.stringify()
使用的,通常不直接使用。
它之所以对外开放,是为了在需要时可以通过给 querystring.escape
赋值一个函数来重写编码的实现。
querystring.parse(str[, sep[, eq[, options]]])#
str
<string> 要解析的 URL 查询字符串。sep
<string> 用于界定查询字符串中的键值对的子字符串。默认为'&'
。eq
<string> 用于界定查询字符串中的键与值的子字符串。默认为'='
。options
<Object>decodeURIComponent
<Function> 解码查询字符串的字符时使用的函数。默认为querystring.unescape()
。maxKeys
<number> 指定要解析的键的最大数量。默认为1000
。指定为0
则不限制。
该方法会把一个 URL 查询字符串 str
解析成一个键值对的集合。
例子,查询字符串 'foo=bar&abc=xyz&abc=123'
被解析成:
{
foo: 'bar',
abc: ['xyz', '123']
}
该方法返回的对象不继承自 JavaScript 的 Object
类。
这意味着 Object
类的方法如 obj.toString()
、obj.hasOwnProperty()
等没有被定义且无法使用。
默认情况下,查询字符串中的字符会被视为使用 UTF-8 编码。
如果使用的是其他字符编码,则需要指定 decodeURIComponent
选项,例如:
// 假设存在 gbkDecodeURIComponent 函数。
querystring.parse('w=%D6%D0%CE%C4&foo=bar', null, null,
{ decodeURIComponent: gbkDecodeURIComponent });
querystring.stringify(obj[, sep[, eq[, options]]])#
obj
<Object> 要序列化成 URL 查询字符串的对象。sep
<string> 用于界定查询字符串中的键值对的子字符串。默认为'&'
。eq
<string> 用于界定查询字符串中的键与值的子字符串。默认为'='
。options
encodeURIComponent
<Function> 把对象中的字符转换成查询字符串时使用的函数。默认为querystring.escape()
。
该方法通过遍历给定的 obj
对象的自身属性,生成 URL 查询字符串。
如果 obj
对象中的属性的类型为
<string> |
<number> |
<boolean> |
<string[]> |
<number[]> |
<boolean[]>,则属性的值会被序列化。
其他类型的属性的值会被强制转换为空字符串。
例子:
querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' });
// 返回 'foo=bar&baz=qux&baz=quux&corge='
querystring.stringify({ foo: 'bar', baz: 'qux' }, ';', ':');
// 返回 'foo:bar;baz:qux'
默认情况下,使用 UTF-8 进行编码。
如果需要使用其他编码,则需要指定 encodeURIComponent
选项,例如:
// 假设存在 gbkEncodeURIComponent 函数。
querystring.stringify({ w: '中文', foo: 'bar' }, null, null,
{ encodeURIComponent: gbkEncodeURIComponent });
querystring.unescape(str)#
str
<string>
对给定的 str
进行解码。
该方法是提供给 querystring.parse()
使用的,通常不直接使用。
它之所以对外开放,是为了在需要时可以通过给 querystring.unescape
赋值一个函数来重写解码的实现。
默认使用 JavaScript 内置的 decodeURIComponent()
方法来解码。
- 断言测试
- 异步钩子(Async Hooks)
- 缓存(Buffer)
- C++ 插件
- C/C++ 插件 - N-API
- 子进程
- 集群(Cluster)
- 命令行参数
- 控制台(Console)
- 加密(Crypto)
- 调试器
- 废弃的 API
- DNS
- 域(Domain)
- ECMAScript 模块
- 错误(Errors)
- 事件(Events)
- 文件系统
- 全局对象(Globals)
- HTTP
- HTTP/2
- HTTPS
- 检查工具(Inspector)
- 国际化
- 模块(Modules)
- 网络(Net)
- 操作系统(OS)
- 路径(Path)
- 性能钩子(Performance Hooks)
- 进程
- Punycode
- 查询字符串
- 逐行读取
- 交互式解释器(REPL)
- 流(Stream)
- 字符串解码
- 定时器(Timers)
- 安全传输层(TLS/SSL)
- 事件跟踪(Tracing)
- TTY
- UDP / 数据报
- URL
- 工具集
- V8
- 虚拟机(VM)
- 压缩(ZLIB)