querystring
模块提供了一些使用函数,用于解析与格式化URL查询字符串
const querystring = require('querystring')
querystring.escape(str)
对给定的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() 等没有被定义且无法使用。
querystring.stringify(obj[, sep[, eq[, options]]])
obj
<Object> 要序列化成 URL 查询字符串的对象。sep
<string> 用于界定查询字符串中的键值对的子字符串。默认为'&'
。eq
<string> 用于界定查询字符串中的键与值的子字符串。默认为'='
。-
options
-
encodeURIComponent
<Function> 把对象中的字符转换成查询字符串时使用的函数。默认为querystring.escape()
。
如果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解码
该方法是提供给querystring.parse()
使用的
默认使用JavaScript内置的decodeURIComponent()
方法来解码