Punycode
Устарело с версии: v7.0.0
[Stable: 0 - Deprecated]
Stable: 0 Stability: 0 - Устарело
Исходный код: lib/punycode.js
Версия модуля punycode, поставляемая в комплекте с Node.js, устаревает. В будущей основной версии Node.js этот модуль будет удален. Пользователям, в настоящее время зависящим от модуля punycode
, следует перейти на использование модуля Punycode.js, предоставляемого пользователями. Для кодирования URL-адресов на основе punycode см. url.domainToASCII
или, в более общем плане, WHATWG URL API.
Модуль punycode
является связанной версией модуля Punycode.js. Доступ к нему можно получить с помощью:
const punycode = require('node:punycode');
Punycode — это схема кодирования символов, определенная в RFC 3492, которая в основном предназначена для использования в интернационализированных доменных именах. Поскольку имена хостов в URL-адресах ограничены только символами ASCII, доменные имена, содержащие символы, отличные от ASCII, должны быть преобразованы в ASCII с использованием схемы Punycode. Например, японский символ, который переводится на английское слово 'example'
, — это '例'
. Интернационализированное доменное имя '例.com'
(эквивалентно 'example.com'
) представлено Punycode как ASCII-строка 'xn--fsq.com'
.
Модуль punycode
предоставляет простую реализацию стандарта Punycode.
Модуль punycode
является сторонней зависимостью, используемой Node.js и предоставляемой разработчикам для удобства. Исправления или другие изменения в модуль должны быть направлены в проект Punycode.js.
punycode.decode(string)
Добавлено в версии: v0.5.1
string
<string>
Метод punycode.decode()
преобразует строку Punycode, состоящую только из символов ASCII, в эквивалентную строку кодовых точек Unicode.
punycode.decode('maana-pta'); // 'mañana'
punycode.decode('--dqo34k'); // '☃-⌘'
punycode.encode(string)
Добавлено в: v0.5.1
string
<string>
Метод punycode.encode()
преобразует строку кодовых точек Unicode в строку Punycode символов, состоящую только из ASCII.
punycode.encode('mañana'); // 'maana-pta'
punycode.encode('☃-⌘'); // '--dqo34k'
punycode.toASCII(domain)
Добавлено в: v0.6.1
domain
<string>
Метод punycode.toASCII()
преобразует Unicode-строку, представляющую интернационализированное доменное имя, в Punycode. Будут преобразованы только не-ASCII части доменного имени. Вызов punycode.toASCII()
для строки, которая уже содержит только ASCII-символы, не окажет никакого эффекта.
// кодирование доменных имен
punycode.toASCII('mañana.com'); // 'xn--maana-pta.com'
punycode.toASCII('☃-⌘.com'); // 'xn----dqo34k.com'
punycode.toASCII('example.com'); // 'example.com'
punycode.toUnicode(domain)
Добавлено в: v0.6.1
domain
<string>
Метод punycode.toUnicode()
преобразует строку, представляющую доменное имя, содержащее символы, закодированные Punycode, в Unicode. Будут преобразованы только части доменного имени, закодированные Punycode.
// декодирование доменных имен
punycode.toUnicode('xn--maana-pta.com'); // 'mañana.com'
punycode.toUnicode('xn----dqo34k.com'); // '☃-⌘.com'
punycode.toUnicode('example.com'); // 'example.com'
punycode.ucs2
Добавлено в: v0.7.0
punycode.ucs2.decode(string)
Добавлено в: v0.7.0
string
<string>
Метод punycode.ucs2.decode()
возвращает массив, содержащий числовые значения кодовых точек каждого символа Unicode в строке.
punycode.ucs2.decode('abc'); // [0x61, 0x62, 0x63]
// суррогатная пара для U+1D306 тетраграмма для центра:
punycode.ucs2.decode('\uD834\uDF06'); // [0x1D306]
punycode.ucs2.encode(codePoints)
Добавлено в: v0.7.0
codePoints
<integer[]>
Метод punycode.ucs2.encode()
возвращает строку на основе массива числовых значений кодовых точек.
punycode.ucs2.encode([0x61, 0x62, 0x63]); // 'abc'
punycode.ucs2.encode([0x1D306]); // '\uD834\uDF06'
punycode.version
Добавлено в: v0.6.1
Возвращает строку, идентифицирующую текущий номер версии Punycode.js.