Преобразование объектов в простые значения, используемое операторами +
и ==
, предусматривает особый подход для объектов Date
. Класс Date
является единственным типом данных в базовом JavaScript, который определяет осмысленные преобразования и в строку, и в число. Преобразование любого объекта, не являющегося датой, в простое значение основано на преобразовании в число (когда первым применяется метод valueOf()
), тогда как для объектов типа Date
используется преобразование в строку (первым применяется метод toString()
). Однако преобразование выполняется не совсем так, как было описано выше: простое значение, возвращаемое методом valueOf()
или toString(),
используется непосредственно, без дополнительного преобразования в число или в строку.
Оператор <
и другие операторы отношений выполняют преобразование объектов в простые значения подобно оператору ==
, но не выделяя объекты Date: для любого объекта сначала предпринимается попытка применить метод valueOf()
, а затем метод toString()
. Любое простое значение, полученное таким способом, используется непосредственно, без дальнейшего преобразования в число или в строку.
+, ==, !=
и операторы отношений являются единственными, выполняющими специальное преобразование строки в простое значение. Другие операторы выполняют более явные преобразования в заданный тип и не предусматривают специальной обработки объектов Date
. Оператор -
, например, преобразует свои операнды в числа. Следующий фрагмент демонстрирует поведение операторов +, -, ==
и >
при работе с объектами Date
:
var now = new Date(); // Создать объект Date
typeof (now +1) // => "строка": + преобразует дату в строку
typeof (now - 1) // => "число": - выполнит преобразование объекта в число
now == now.toString() // => true: неявное и явное преобразование в строку
now > (now -1) // => true: > преобразует объект Date в число
3.9. Объявление переменных
Прежде чем использовать переменную в JavaScript, ее необходимо объявить. Переменные объявляются с помощью ключевого слова var следующим образом:
var і;
var sum;
Один раз использовав ключевое слово var, можно объявить несколько переменных:
var і, sum;
Объявление переменных можно совмещать с их инициализацией:
var message = "hello";
var i = 0, j = 0. k = 0;
Если начальное значение в инструкции var не задано, то переменная объявляется, но ее начальное значение остается неопределенным ( undefined
), пока не будет изменено программой.
Обратите внимание, что инструкция var
также может включаться в циклы for
и for/in
(о которых рассказывается в главе 5), что позволяет объявлять переменную цикла непосредственно в самом цикле. Например:
for(var і = 0; і < 10; i++) console.log(i);
for(var і = 0, j=10; і < 10; i++,J —) console.log(i*j);
for(var p in o) console.log(p);
Если вы имеете опыт использования языков программирования со статическими типами данных, таких как С или Java, то можете заметить, что в объявлениях переменных в языке JavaScript отсутствует объявление типа. Переменные в языке JavaScript могут хранить значения любых типов. Например, в JavaScript допускается присвоить некоторой переменной число, а затем этой же переменной присвоить строку:
var і = 10;
і = "ten";
3.9.1 Повторные и опущенные объявления
С помощью инструкции var МОЖНО объявить одну и ту же переменную несколько раз. Если повторное объявление содержит инициализатор, то оно действует как обычная инструкция присваивания.
Если попытаться прочитать значение необъявленной переменной, JavaScript сгенерирует ошибку. В строгом режиме, предусмотренном стандартом ECMAScript 5 (раздел 5.7.3), ошибка также возбуждается при попытке присвоить значение необъявленной переменной. Однако исторически и при выполнении не в строгом режиме, если присвоить значение переменной, не объявленной с помощью инструкции var
, то JavaScript создаст эту переменную как свойство глобального объекта, и она будет действовать практически так же (но с некоторыми отличиями, описываемыми в разделе 3.10.2), как корректно объявленная переменная. Это означает, что глобальные переменные можно не объявлять. Однако это считается дурной привычкой и может явиться источником ошибок, поэтому всегда старайтесь объявлять свои переменные с помощью var
.
Читать дальше
Конец ознакомительного отрывка
Купить книгу