Дэвид Флэнаган - JavaScript. Подробное руководство, 6-е издание
- Название:JavaScript. Подробное руководство, 6-е издание
- Автор:
- Жанр:
- Издательство:Символ-Плюс
- Год:2012
- Город:СПб
- ISBN:978-5-93286-215-5
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Дэвид Флэнаган - JavaScript. Подробное руководство, 6-е издание краткое содержание
Эта книга - одновременно и руководство программиста, и полноценный справочник по базовому языку JavaScript и клиентским прикладным интерфейсам, предоставляемым веб-броузерами.
JavaScript. Подробное руководство, 6-е издание - читать онлайн бесплатно ознакомительный отрывок
Интервал:
Закладка:
Таблица 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. Работа со строками
Одной из встроенных возможностей JavaScript является способность конкатенировать строки. Если оператор + применяется к числам, они складываются, а если к строкам - они объединяются, при этом вторая строка добавляется в конец первой. Например:
msg = "Hello, " + "world"; // Получается строка "Hello, world"
greeting = "Добро пожаловать на мою домашнюю страницу," + " " + name;
Для определения длины строки - количества содержащихся в ней 16-битных значений - используется свойство строки length
. Например, длину строки s можно получить следующим образом:
s.length
Кроме того, в дополнение к свойству length
строки имеют множество методов (как обычно, более полную информацию ищите в справочном разделе):
var s = "hello, world" // Начнем с того же текста.
s.charAt(0) // => "h": первый символ.
s.charAt(s.length-1) // => "d": последний символ.
s.substring(1,4) // => "ell": 2-й, 3-й и 4-й символы.
s.slice(1,4) // => "ell": то же самое
s.slice(-3) // => "rld": последние 3 символа
s.indexOf("l") // => 2: позиция первого символа l.
s.lastlndexOf('l') // => 10: позиция последнего символа l.
s.indexOf("l", 3) // => 3: позиция первого символа ”1", следующего
// за 3 символом в строке
s.split(",") // => ["hello", "world"] разбивает на подстроки
s.replace("h", "H") // => "Hello, world": замещает все вхождения подстроки
s.toUpperCase() // => "HELLO, WORLD"
Не забывайте, что строки в JavaScript являются неизменяемыми. Такие методы, как герlасе()
и toUpperCase()
возвращают новые строки: они не изменяют строку, относительно которой были вызваны.
В стандарте ECMAScript 5 строки могут интерпретироваться как массивы, доступные только для чтения, и вместо использования метода charAt() к отдельным символам (16-битным значениям) строки можно обращаться с помощью индексов в квадратных скобках:
s = "hello, world";
s[0] // => "h"
s[s.length-1] // => "d"
Веб-броузеры, основанные на движке Mozilla, такие как Firefox, уже давно предоставляют такую возможность. Большинство современных броузеров (заметным исключением из которых является IE) последовали за Mozilla еще до того, как эта особенность была утверждена в стандарте ECMAScript 5.
3.2.4. Сопоставление с шаблонами
В языке JavaScript определен конструктор RegExp(),
предназначенный для создания объектов, представляющих текстовые шаблоны. Эти шаблоны описываются с помощью регулярных выражений, синтаксис которых был заимствован языком JavaScript из языка Perl. И строки, и объекты RegExp
имеют методы, позволяющие выполнять операции сопоставления с шаблоном и поиска с заменой при помощи регулярных выражений.
RegExp не относится к числу фундаментальных типов данных языка JavaScript. Подобно объектам Date
, они просто являются специализированной разновидностью объектов с удобным прикладным интерфейсом. Грамматика регулярных выражений и прикладной интерфейс отличаются повышенной сложностью. Они подробно описываются в главе 10. Однако поскольку объекты RegExp
обладают широкими возможностями и часто используются на практике, мы коротко познакомимся с ними в этом разделе.
Несмотря на то что объекты RegExp
не относятся к фундаментальным типам данных языка, они имеют синтаксис литералов и могут вставляться непосредственно в текст программы на языке JavaScript. Текст, заключенный в пару символов слэша, интерпретируется как литерал регулярного выражения. За вторым символом слэша из этой пары может следовать один или более символов, которые модифицируют поведение шаблона. Например:
/"HTML/ // Соответствует символам Н Т М L в начале строки
/[ 1-9][0-9]*/ // Соответствует цифре, кроме нуля, за которой следует любое число цифр
/\bjavascript\b/i // Соответствует подстроке "javascript”
// как отдельному слову, учитывает регистр символов
Объекты RegExp обладают множеством полезных методов. Кроме того, строки также обладают методами, которые принимают объекты RegExp в виде аргументов. Например:
var text = "testing: 1, 2, 3”; // Образец текста
var pattern = /\d+/g // Соответствует всем вхождениям одной или более цифр
pattern.test(text) // => true: имеется совпадение
text.search(pattern) // => 9: позиция первого совпадения
text.match(pattern) // => ["1", "2", "3"]: массив всех совпадений
text.replace(pattern,'#');
// => "testing: tf, tf. #"
text.split(/\D+/); // =>"1","2","3"]: разбить по нецифровым символам
3.3. Логические значения
Логическое значение говорит об истинности или ложности чего-то. Логический тип данных имеет только два допустимых логических значения. Эти два значения представлены литералами true
и false
.
Логические значения обычно представляют собой результат операций сравнения, выполняемых в JavaScript-программах. Например:
а == 4
Это выражение проверяет, равно ли значение переменной а числу 4. Если да, результатом этого сравнения будет логическое значение true
. Если значение переменной а не равно 4, результатом сравнения будет false
.
Логические значения обычно используются в управляющих конструкциях JavaScript. Например, инструкция if/else
в JavaScript выполняет одно действие, если логическое значение равно true
, и другое действие, если false
. Обычно сравнение, создающее логическое значение, непосредственно объединяется с инструкцией, в которой оно используется. Результат выглядит так:
if (а == 4)
b = b + 1;
else
а = а + 1:
Здесь выполняется проверка равенства значения переменной а числу 4. Если равно, к значению переменной b добавляется 1; в противном случае число 1 добавляется к значению переменной а.
Читать дальшеИнтервал:
Закладка: