無論是前端還是后端,經常出現的應用場景是URL中參數的處理。nodeJS的queryString模塊提供了一些處理 query strings 的工具。本文將詳細介紹nodeJS中的queryString
var querystring = require('querystring');/*{ unescapeBuffer: [Function], unescape: [Function: qsUnescape], escape: [Function], encode: [Function], stringify: [Function], decode: [Function], parse: [Function] } */console.log(querystring);querystring.parse()方法能把一個URL查詢字符串(str)解析成一個鍵值對的集合,參數如下
str <String> 要解析的 URL 查詢字符串。
sep <String> 用于界定查詢字符串中的鍵值對的子字符串。默認為 '&'。
eq <String> 用于界定查詢字符串中的鍵與值的子字符串。默認為 '='。
options <Object>
decodeURIComponent <Function> 當解碼查詢字符串中百分號編碼的字符時使用的函數。默認為 querystring.unescape()
maxKeys <number> 指定要解析的鍵的最大數量。默認為 1000。指定為 0 則移除鍵數的限制
var querystring = require('querystring');var str = 'foo=bar&abc=xyz&abc=123';console.log(querystring.parse(str));//'{ foo: 'bar', abc: [ 'xyz', '123' ] }'第二個參數用于界定查詢字符串中的鍵值對的子字符串
var querystring = require('querystring');var str = 'foo=bar&abc=xyz&abc=123';console.log(querystring.parse(str,'a'));//{ foo: 'b', 'r&': '', bc: [ 'xyz&', '123' ] }第三個參數用于界定查詢字符串中的鍵與值的子字符串
var querystring = require('querystring');var str = 'foo=bar&abc=xyz&abc=123';console.log(querystring.parse(str,'&','c'));//{ 'foo=bar': '', ab: [ '=xyz', '=123' ] }[注意]querystring.parse()方法返回的對象不繼承自 JavaScript 的 Object。 這意味著典型的 Object 方法如 obj.toString()、obj.hasOwnProperty() 等沒有被定義且無法使用
默認情況下,查詢字符串中的百分號編碼的字符會被認為使用了 UTF-8 編碼。 如果使用的是另一種字符編碼,則 decodeURIComponent 選項需要被指定
var querystring = require('querystring');//{ w: '����', foo: 'bar' }console.log(querystring.parse('w=%D6%D0%CE%C4&foo=bar', null, null,{ decodeURIComponent: 'gbkDecodeURIComponent' }));querystring.stringify()方法是querystring.parse()方法的逆向操作,通過遍歷對象的自有屬性,從一個給定的obj產生一個URL查詢字符串,參數如下
obj <Object> 要序列化成一個 URL 查詢字符串的對象
sep <String> 用于界定查詢字符串中的鍵值對的子字符串。默認為 '&'
新聞熱點
疑難解答
圖片精選