var Р = "71": // 71 - это 1 символ с 16-битным кодовым пунктом 0х0Зс0
var е = " е "; // е - это 1 символ с 17-битным кодовым пунктом 0x1d452
р.length // => 1: р содержит единственный 16-битный элемент
е.length // => 2: в кодировке UTF-16 символ е определяется двумя
// 16-битными значениями: "\ud835\udc52"
Различные строковые методы, имеющиеся в языке JavaScript, манипулируют 16-битными значениями, а не символами. Они не предусматривают возможность специальной интерпретации суррогатных пар, не выполняют нормализацию строк и даже не проверяют, является ли строка последовательностью символов в кодировке UTF-16.
*********************************************
Обратите внимание, что, ограничивая строку одинарными кавычками, необходимо проявлять осторожность в обращении с апострофами, употребляемыми в английском языке для обозначения притяжательного падежа и в сокращениях; как, например, в словах «can’t» и «O’Reilly’s». Поскольку апостроф и одиночная кавычка - это одно и то же, необходимо при помощи символа обратного слэша (\) «экранировать» апострофы, расположенные внутри одиночных кавычек (подробнее об этом - в следующем разделе).
Программы на клиентском JavaScript часто содержат строки HTML-кода, а HTML-код, в свою очередь, часто содержит строки JavaScript-кода. Как и в JavaScript, в языке HTML для ограничения строк применяются либо одинарные, либо двойные кавычки. Поэтому при объединении JavaScript- и HTML-кода есть смысл придерживаться одного «стиля» кавычек для JavaScript, а другого - для HTML. В следующем примере строка «Спасибо» в JavaScript-выражении заключена в одинарные кавычки, а само выражение, в свою очередь, заключено в двойные кавычки как значение HTML-атрибута обработчика событий:
Щелкни на мнe
3.2.2. Управляющие последовательности в строковых литералах
Символ обратного слэша ( \
) имеет специальное назначение в JavaScript-строках. Вместе с символами, следующими за ним, он обозначает символ, не представимый внутри строки другими способами. Например, \n
- это управляющая последовательность (escape sequence), обозначающая символ перевода строки.
Другой пример, упомянутый выше, - это последовательность \'
, обозначающая символ одинарной кавычки. Эта управляющая последовательность необходима для включения символа одинарной кавычки в строковый литерал, заключенный в одинарные кавычки. Теперь становится понятно, почему мы называем эти последовательности управляющими - здесь символ обратного слэша позволяет управлять интерпретацией символа одинарной кавычки. Вместо того чтобы отмечать ею конец строки, мы используем ее как апостроф:
'You\'re right, it can\'t be a quote'
В табл. 3.1 перечислены управляющие последовательности JavaScript и обозначаемые ими символы. Две управляющие последовательности являются обобщенными; они могут применяться для представления любого символа путем указания кода символа из набора Latin-І или Unicode в виде шестнадцатеричного числа. Например, последовательность \хА9 обозначает символ копирайта, который в кодировке Latin-І имеет шестнадцатеричный код А9. Аналогично управляющая последовательность, начинающаяся с символов \и, обозначает произвольный символ Юникода, заданный четырьмя шестнадцатеричными цифрами. Например, \u03c0 обозначает символ л.
Если символ «\» предшествует любому символу, отличному от приведенных в табл. 3.1, обратный слэш просто игнорируется (хотя будущие версии могут, конечно, определять новые управляющие последовательности). Например, \# - это то же самое, что и #. Наконец, как отмечалось выше, стандарт ECMAScript 5 позволяет добавлять в многострочные строковые литералы символ обратного слэша перед разрывом строки.
Таблица 3.1. Управляющие последовательности JavaScript |
Последовательность |
Представляемый символ |
\о |
Символ NUL (\u0000) |
\Ь |
«Забой» (\u0008) |
\t |
Горизонтальная табуляция (\u0009) |
\n |
Перевод строки (\u000А) |
\v |
Вертикальная табуляция (\u000В) |
\f |
Перевод страницы (\u000С) |
\r |
Возврат каретки (\u000D) |
\" |
Двойная кавычка (\u0022) |
\' |
Одинарная кавычка (\u0027) |
\\ |
Обратный слэш (\u005C) |
\хХХ |
Символ Latin-1, заданный двумя шестнадцатеричными цифрами XX |
\uxXXXX |
Символ Unicode, заданный четырьмя шестнадцатеричными цифрами хххх |
3.2.3. Работа со строками
Читать дальше
Конец ознакомительного отрывка
Купить книгу