--- title: String.fromCodePoint() slug: Web/JavaScript/Reference/Global_Objects/String/fromCodePoint tags: - ECMAScript6 - Experimental - Expérimental(2) - JavaScript - Method - Reference - Référence(2) - String translation_of: Web/JavaScript/Reference/Global_Objects/String/fromCodePoint ---
Статический метод String.fromCodePoint()
возвращает строку, созданную из указанной последовательности кодовых точек.
String.fromCodePoint(num1[, ...[, numN]])
num1, ..., numN
Поскольку метод fromCodePoint()
является статическим методом объекта {{jsxref("Global_Objects/String", "String")}}, вы всегда должны использовать его как String.fromCodePoint()
, а не как метод созданного вами экземпляра {{jsxref("Global_Objects/String", "String")}}.
fromCodePoint()
String.fromCodePoint(42); // "*" String.fromCodePoint(65, 90); // "AZ" String.fromCodePoint(0x404); // "\u0404" String.fromCodePoint(0x2F804); // "\uD87E\uDC04" String.fromCodePoint(194564); // "\uD87E\uDC04" String.fromCodePoint(0x1D306, 0x61, 0x1D307) // "\uD834\uDF06a\uD834\uDF07" String.fromCodePoint('_'); // RangeError String.fromCodePoint(Infinity); // RangeError String.fromCodePoint(-1); // RangeError String.fromCodePoint(3.14); // RangeError String.fromCodePoint(3e-2); // RangeError String.fromCodePoint(NaN); // RangeError
// Метод String.fromCharCode() не может вернуть символ по такой большой кодовой точке // Следующий же метод может вернуть 4-байтный символ так же, как и обычный // 2-байтный (то есть, он может вернуть один символ, который на самом деле // имеет длину 2, а не 1!) console.log(String.fromCodePoint(0x2F804)); // или 194564 в десятичной записи
Метод String.fromCodePoint()
был добавлен к стандарту ECMAScript в 6-й версии и может поддерживаться ещё не во всех браузерах или окружениях. Используйте код ниже в качестве полифила:
/*! http://mths.be/fromcodepoint v0.1.0 by @mathias */ if (!String.fromCodePoint) { (function() { var defineProperty = (function() { // IE 8 поддерживает метод `Object.defineProperty` только на элементах DOM try { var object = {}; var $defineProperty = Object.defineProperty; var result = $defineProperty(object, object, object) && $defineProperty; } catch(error) {} return result; }()); var stringFromCharCode = String.fromCharCode; var floor = Math.floor; var fromCodePoint = function() { var MAX_SIZE = 0x4000; var codeUnits = []; var highSurrogate; var lowSurrogate; var index = -1; var length = arguments.length; if (!length) { return ''; } var result = ''; while (++index < length) { var codePoint = Number(arguments[index]); if ( !isFinite(codePoint) || // `NaN`, `+Infinity` или `-Infinity` codePoint < 0 || // неверная кодовая точка Юникода codePoint > 0x10FFFF || // неверная кодовая точка Юникода floor(codePoint) != codePoint // не целое число ) { throw RangeError('Invalid code point: ' + codePoint); } if (codePoint <= 0xFFFF) { // кодовая точка Базовой многоязыковой плоскости (БМП) codeUnits.push(codePoint); } else { // Астральная кодовая точка; делим её на суррогатную пару // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae codePoint -= 0x10000; highSurrogate = (codePoint >> 10) + 0xD800; lowSurrogate = (codePoint % 0x400) + 0xDC00; codeUnits.push(highSurrogate, lowSurrogate); } if (index + 1 == length || codeUnits.length > MAX_SIZE) { result += stringFromCharCode.apply(null, codeUnits); codeUnits.length = 0; } } return result; }; if (defineProperty) { defineProperty(String, 'fromCodePoint', { 'value': fromCodePoint, 'configurable': true, 'writable': true }); } else { String.fromCodePoint = fromCodePoint; } }()); }
Спецификация | Статус | Комментарии |
---|---|---|
{{SpecName('ES6', '#sec-string.fromcodepoint', 'String.fromCodePoint')}} | {{Spec2('ES6')}} | Изначальное определение. |
Возможность | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Базовая поддержка | {{CompatChrome("41")}} | {{CompatGeckoDesktop("29")}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
Возможность | Android | Chrome для Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Базовая поддержка | {{CompatNo}} | {{CompatNo}} | {{CompatGeckoMobile("29")}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |