Punycode.js
在io.js
v1.0.0+ 和 Node.js
v0.6.2+ 中被内置。通过require('punycode')
来获取它(若要在其他版本的io.js
中使用它,需要先通过npm来安装punycode
模块)。
转换一个纯ASCII符号 Punycode
字符串为一个Unicode
符号的字符串。
// decode domain name parts
punycode.decode('maana-pta'); // 'mañana'
punycode.decode('--dqo34k'); // '☃-⌘'
转换一个Unicode
符号的字符串为一个纯ASCII符号 Punycode
字符串。
// encode domain name parts
punycode.encode('mañana'); // 'maana-pta'
punycode.encode('☃-⌘'); // '--dqo34k'
转换一个代表了一个域名的Punycode
字符串为一个Unicode
字符串。只有代表了域名的部分的Punycode
字符串会被转换。也就是说,如果你调用了一个已经被转换为Unicode
的字符串,也是没有问题的。
// decode domain names
punycode.toUnicode('xn--maana-pta.com'); // 'mañana.com'
punycode.toUnicode('xn----dqo34k.com'); // '☃-⌘.com'
转换一个代表了一个域名的Unicode
字符串为一个Unicode
字符串。只有代表了域名的部分的非ASCII字符串会被转换。也就是说,如果你调用了一个已经被转换为ASCII的字符串,也是没有问题的。
// encode domain names
punycode.toASCII('mañana.com'); // 'xn--maana-pta.com'
punycode.toASCII('☃-⌘.com'); // 'xn----dqo34k.com'
创建一个包含了 字符串中的每个Unicode
符号的数字编码点 的数组。由于JavaScript
在内部使用UCS-2
,这个函数会将一对代理部分(surrogate halves)(UCS-2暴露的单独字符)转换为一个单独的编码点 来匹配UTF-16。
punycode.ucs2.decode('abc'); // [0x61, 0x62, 0x63]
// surrogate pair for U+1D306 tetragram for centre:
punycode.ucs2.decode('\uD834\uDF06'); // [0x1D306]
基于数字编码点的数组,创建一个字符串。
punycode.ucs2.encode([0x61, 0x62, 0x63]); // 'abc'
punycode.ucs2.encode([0x1D306]); // '\uD834\uDF06'
一个代表了当前Punycode.js
版本号的数字。