url
モジュールと querystring
モジュールは、2 つの非常に重要な URL
処理モジュールです。 node
サーバー開発を行うときによく使用されます。
url
モジュールを導入する前に、まず写真を撮りましょう。この写真を理解すると、url に役立ちます。
このモジュールでは基本的に問題はありません。
それぞれの意味を説明しましょう
:
が含まれていることに注意してください。小文字。 [関連チュートリアルの推奨事項: nodejs ビデオ チュートリアル 、プログラミング教育 ]:
の後に 2 つの // # が続く場合##、それは本当です。
、パスワードがない場合は
usrname となります。大文字と小文字が区別されることに注意してください。
のようにポートが小文字で含まれていることに注意してください。
が含まれていることに注意してください。また、値はデコードされていません。
から
? を除いたもので他は同じですが、オブジェクトの場合はデコードされます。
# が含まれることに注意してください。
と
host は小文字に変換されることに注意してください。
url 文字列は
object に解析されるため、開発者にとっては操作が便利です。
const url = require("url"); const str = "http://user:password@randy.com:8080/index.html?nick=%E4%B8%AD%E6%96%87#part=1"; const obj = url.parse(str); console.log(obj);
##このメソッドは、他の 2 つのパラメータ
parseQueryString と slashesDenoteHos
# の受け渡しもサポートしています。
##parseQueryString
false の場合、urlObject.query は
nick= Chinese # などの解析されていない文字列です。 ##、対応する値は decode
ではありません; parseQueryString
が true の場合、urlObject.query
は object
になります (例: #) ##{ ニックネーム: '中国語' }、値は `デコードされます;
const url = require("url"); const str = "http://user:password@randy.com:8080/index.html?nick=%E4%B8%AD%E6%96%87#part=1"; const obj2 = url.parse(str, true); console.log(obj2);
slashesDenoteHos: (デフォルトは false) true
の場合、//randy/nick の randy は
hostname とみなされます。
false# の場合、 ## の場合、randy
は pathname
の一部とみなされます。 この文の意味が分からないと思われるかもしれませんが、以下に例を挙げて説明しますので、理解してもらえると思います。
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false;">const str2 = "//randy/nick";
const obj3 = url.parse(str2, true, false);
console.log(obj3);
const obj4 = url.parse(str2, true, true);
console.log(obj4);</pre><div class="contentsignin">ログイン後にコピー</div></div>
format(urlObject)
このメソッドは、
parseconst pathObj = { protocol: "http:", slashes: true, auth: "user:password", host: "randy.com:8080", port: "8080", hostname: "randy.com", hash: "#part=1", search: "?nick=%E4%B8%AD%E6%96%87", query: "nick=%E4%B8%AD%E6%96%87", pathname: "/index.html", path: "/index.html?nick=%E4%B8%AD%E6%96%87", href: "http://user:password@randy.com:8080/index.html?nick=%E4%B8%AD%E6%96%87#part=1", }; console.log(url.format(pathObj)); // http://user:password@randy.com:8080/index.html?nick=%E4%B8%AD%E6%96%87#part=1
resolve(from, to)
このメソッドは、ベース
console.log(url.resolve("/one/two/three", "four")); // /one/two/four console.log(url.resolve("http://example.com/", "/one")); // http://example.com/one console.log(url.resolve("http://example.com/one", "/two")); // http://example.com/two console.log(url.resolve("http://example.com/one/ddd/ddd/ddd", "./two")); // http://example.com/one/ddd/ddd/two console.log(url.resolve("http://example.com/one/ddd/ddd/ddd", "../two")); // http://example.com/one/ddd/two console.log(url.resolve("http://example.com/one/ddd/ddd/ddd", ".../two")); // http://example.com/one/ddd/ddd/.../two
クエリ文字列クエリ文字列
stringify の分析に焦点を当てます。
parse(str, sep, eq, options)
parse
const querystring = require("querystring"); const str = "nick=randy&age=24&nick2=%E4%B8%AD%E6%96%87"; const obj = querystring.parse(str); console.log(obj); // { nick: 'randy', age: '24', nick2: '中文' }
& と = を外字に置き換えることに相当します。以下に著者が例を挙げますので、すぐに理解できると思います。
const str1 = "name-randy|country-cn"; const obj1 = querystring.parse(str1); console.log(obj1); // { 'name-randy|country-cn': '' } const obj2 = querystring.parse(str1, "|", "-"); console.log(obj2); // { name: 'randy', country: 'cn' }
は、
& を | に置き換え、
=
- に置き換えることと同じです。著者は、このような状況はまれであるはずだと感じています。
stringify(obj, sep, eq, options)
このメソッドは、上記の
parse
const obj3 = { nick: "randy", age: "24", }; const str4 = querystring.stringify(obj3); console.log(str4); // nick=randy&age=24
const obj5 = { name: "randy", country: "cn", }; const str6 = querystring.stringify(obj5, "|", "-"); console.log(str6); // name-randy|country-c
更多node相关知识,请访问:nodejs 教程!
以上がNode の URL モジュールとクエリ文字列モジュールについて話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。