Node.js v18.18.2 文档


目录

Punycode 国际化域名编码#

稳定性:0 - 已弃用

源代码: lib/punycode.js

Node.js 中捆绑的 punycode 模块版本已被弃用。 在 Node.js 的未来主要版本中,该模块将被删除。当前依赖于punycode模块的用户应改用用户空间提供的Punycode.js模块。对于基于 punycode 的 URL 编码,请参阅url.domainToASCII,或者更一般地说,请参阅 WHATWG URL API

punycode模块是Punycode.js模块的捆绑版本。可以使用以下方式访问它:

const punycode = require('punycode'); 

Punycode是 RFC 3492 定义的字符编码方案,主要用于国际化域名。由于 URL 中的主机名仅限于 ASCII 字符,因此包含非 ASCII 字符的域名必须使用 Punycode 方案转换为 ASCII。例如,翻译成英语单词 'example'的日语字符是'例'。国际化域名'例.com'(相当于'example.com')由 Punycode 表示为 ASCII 字符串 'xn--fsq.com'

punycode模块提供了 Punycode 标准的简单实现。

punycode模块是 Node.js 使用的第三方依赖项,为方便开发者而提供。对模块的修复或其他修改必须针对Punycode.js项目。

punycode.decode(string)#

punycode.decode()方法将纯 ASCII 字符的Punycode字符串转换为等效的 Unicode 代码点字符串。

punycode.decode('maana-pta'); // 'mañana'
punycode.decode('--dqo34k'); // '☃-⌘' 

punycode.encode(string)#

punycode.encode()方法将 Unicode 代码点字符串转换为 纯 ASCII 字符的Punycode字符串。

punycode.encode('mañana'); // 'maana-pta'
punycode.encode('☃-⌘'); // '--dqo34k' 

punycode.toASCII(domain)#

punycode.toASCII()方法将表示国际化域名的 Unicode 字符串转换为Punycode。仅域名的非 ASCII 部分将被转换。对仅包含 ASCII 字符的字符串调用punycode.toASCII()不会产生任何效果。

// encode domain names
punycode.toASCII('mañana.com');  // 'xn--maana-pta.com'
punycode.toASCII('☃-⌘.com');   // 'xn----dqo34k.com'
punycode.toASCII('example.com'); // 'example.com' 

punycode.toUnicode(domain)#

punycode.toUnicode()方法将表示包含Punycode编码字符的域名的字符串转换为 Unicode。仅 转换域名的Punycode编码部分。

// decode domain names
punycode.toUnicode('xn--maana-pta.com'); // 'mañana.com'
punycode.toUnicode('xn----dqo34k.com');  // '☃-⌘.com'
punycode.toUnicode('example.com');       // 'example.com' 

punycode.ucs2#

punycode.ucs2.decode(string)#

punycode.ucs2.decode()方法返回一个数组,其中包含字符串中每个 Unicode 符号的数字代码点值。

punycode.ucs2.decode('abc'); // [0x61, 0x62, 0x63]
// surrogate pair for U+1D306 tetragram for centre:
punycode.ucs2.decode('\uD834\uDF06'); // [0x1D306] 

punycode.ucs2.encode(codePoints)#

punycode.ucs2.encode()方法返回基于数字代码点值数组的字符串。

punycode.ucs2.encode([0x61, 0x62, 0x63]); // 'abc'
punycode.ucs2.encode([0x1D306]); // '\uD834\uDF06' 

punycode.version#

返回标识当前Punycode.js版本号的字符串。

NodeJS中文文档为Read dev Docs平台提供托管,中文NodeJS文档均由英文版NodeJS文档翻译,版权属于nodejs.org