- assert - 断言
- Buffer - 缓冲器
- child_process - 子进程
- cluster - 集群
- console - 控制台
- crypto - 加密
- dgram - 数据报
- dns - 域名服务器
- Error - 异常
- events - 事件
- fs - 文件系统
- global - 全局变量
- http - HTTP
- https - HTTPS
- module - 模块
- net - 网络
- os - 操作系统
- path - 路径
- process - 进程
- querystring - 查询字符串
- readline - 逐行读取
- repl - 交互式解释器
- stream - 流
- string_decoder - 字符串解码器
- timer - 定时器
- tls - 安全传输层
- tty - 终端
- url - 网址
- util - 实用工具
- v8 - V8引擎
- vm - 虚拟机
- zlib - 压缩
Node.js v10.8.0 文档
目录
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> 指定要解析的键的最大数量。指定为- 0则不限制。默认为- 1000。
 
该方法会把一个 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() 方法来解码。