JavaScript. Подробное руководство, 6-е издание, стр. 28

<b>parselnt(&quot;11&quot;, 2);  // =&gt; 3 (1*2 + 1)</b>

<b>parselnt(&quot;ff”, 16); // =&gt; 255 (15*16 + 15)</b>

<b>parselnt(&quot;zz&quot;, 36); // =&gt; 1295 (35*36 + 35)</b>

<b>parselnt(&quot;077&quot;, 8); // =&gt; 63 (7*8 + 7)</b>

<b>parselnt(&quot;077&quot;, 10) // =&gt; 77 (7*10 + 7)</b>

3.8.3. Преобразование объектов в простые значения

Преобразование объектов в логические значения выполняется очень просто: все объекты (включая массивы и функции) преобразуются в значение true. Это справедливо и для объектов-оберток: результатом вызова new Boolean (false) является объект, а не простое значение, поэтому он также преобразуется в значение true.

Преобразование объекта в строку и преобразование объекта в число выполняется вызовом соответствующего метода объекта. Все осложняется тем, что объекты в языке JavaScript имеют два разных метода для выполнения преобразований, а также наличием нескольких специальных случаев, описываемых ниже. Обратите внимание, что правила преобразования объектов в строки и числа, описываемые здесь, применяются только к объектам самого языка JavaScript. Объекты среды выполнения (например, определяемые веб-броузерами) могут предусматривать собственные алгоритмы преобразования в числа и строки.

Все объекты наследуют два метода преобразования. Первый из них называется toString(), он возвращает строковое представление объекта. По умолчанию метод toString() не возвращает ничего особенно интересного (хотя эта информация иногда может оказаться полезной, как будет показано в примере 6.4):

<b>({x:1, y:2}).toString() // =&gt; &quot;[object Object]&quot;</b>

Многие классы определяют более специализированные версии метода

<b>toString()</b>
. Например, метод
<b>toString()</b>
класса
<b>Array</b>
преобразует все элементы массива в строки и объединяет результаты в одну строку, вставляя запятые между ними. Метод
<b>toString()</b>
класса
<b>Function</b>
возвращает строковое представление функции, зависящее от реализации. На практике обычно реализации преобразуют пользовательские функции в строки с исходным программным кодом на языке JavaScript.

Класс

<b>Date</b>
определяет метод
<b>toString(),</b>
возвращающий строку с датой и временем в удобочитаемом формате (который может быть разобран средствами JavaScript). Класс
<b>RegExp</b>
определяет метод
<b>toString(),</b>
преобразующий объект
<b>RegExp</b>
в строку, которая выглядит как литерал регулярного выражения:

<b>[1,2.3].toString() // =&gt; &quot;1.2,3&quot;</b>

<b>(function(x) { f(x); }).toString() // =&gt; &quot;function(x) {\n f(x);\n}&quot;</b>

<b>/\d+/g.toString() // =&gt; &quot;/\\d+/g&quot;</b>

<b>new Date(2010,0,1).toString() // =&gt; &quot;Fri Jan 01 2010 00:00:00 GMT+0300&quot;</b>

Другая функция преобразования объектов называется

<b>valueOf().</b>
Задача этого метода определена не так четко: предполагается, что он должен преобразовать объект в представляющее его простое значение, если такое значение существует. Объекты по своей природе являются составными значениями, и большинство объектов не могут быть представлены в виде единственного простого значения, поэтому по умолчанию метод
<b>valueOf()</b>
возвращает не простое значение, а сам объект. Классы-обертки определяют методы
<b>valueOf(),</b>
возвращающие обернутые простые значения. Массивы, функции и регулярные выражения наследуют метод по умолчанию. Вызов метода
<b>valueOf()</b>
экземпляров этих типов возвращает сам объект. Класс
<b>Date</b>
определяет метод
<b>valueOf()</b>
, возвращающий дату во внутреннем представлении: количество миллисекунд, прошедших с 1 января 1970 года:

<b>var d = new Date(2010, 0, 1); // 1 января 2010 года, (время Московское)</b>

<b>d.valueOf() // =&gt; 1262293200000</b>

Теперь, разобравшись с методами

<b>toString()</b>
и
<b>valueOf(),</b>
можно перейти к обсуждению особенностей преобразования объектов в строки и в числа. Учтите, что существует несколько специальных случаев, когда JavaScript выполняет преобразование объектов в простые значения несколько иначе. Эти особые случаи рассматриваются в конце данного раздела.

Преобразование объектов в строку интерпретатор JavaScript выполняет в два этапа:

• Если объект имеет метод

<b>toString(),</b>
интерпретатор вызывает его. Если он возвращает простое значение, интерпретатор преобразует значение в строку (если оно не является строкой) и возвращает результат преобразования. Обратите внимание, что правила преобразований простых значений в строку четко определены для всех типов и перечислены в табл. 3.2.

• Если объект не имеет метода

<b>toString()</b>
или этот метод не возвращает простое значение, то интерпретатор проверяет наличие метода
<b>valueOf().</b>
Если этот метод определен, интерпретатор вызывает его. Если он возвращает простое значение, интерпретатор преобразует это значение в строку (если оно не является строкой) и возвращает результат преобразования.

• В противном случае интерпретатор делает вывод, что ни

<b>toString(),</b>
ни
<b>valueOf()</b>
не позволяют получить простое значение и возбуждает исключение TypeError.

При преобразовании объекта в число интерпретатор выполняет те же действия, но первым пытается применить метод

<b>valueOf():</b>

• Если объект имеет метод

<b>valueOf(),</b>
возвращающий простое значение, интерпретатор преобразует (при необходимости) это значение в число и возвращает результат.

• Иначе, если объект имеет метод

<b>toString(),</b>
возвращающий простое значение, интерпретатор выполняет преобразование и возвращает полученное значение.