JavaScript. Подробное руководство, 6-е издание, стр. 26
<b> for(var і = 0; і < a.length; і++) // Цикл по всем элементам</b><b> if (а[і] !== b[i]) return false; // Если хоть один элемент</b><b> // отличается, массивы не равны </b><b> return true; // Иначе они равны</b><b>}</b>3.8. Преобразование типов
JavaScript может гибко преобразовывать один тип в другой. Мы уже могли убедиться в этом на примере логических значений: везде, где интерпретатор JavaScript ожидает получить логическое значение, можно указать значение любого типа и JavaScript автоматически выполнит необходимое преобразование. Одни значения («истинные» значения) преобразуются в значение
<b>true</b><b>false</b><b>NaN</b><b>10 + " objects" // => "10 objects". Число 10 преобразуется в строку </b><b>"7" * "4" // => 28: обе строки преобразуются в числа</b><b>var n = 1 - "x"; // => NaN: строка "x" не может быть преобразована в число </b><b>n + " objects" // => "NaN objects": NaN преобразуется в строку "NaN"</b>В табл. 3.2 описывается, как в JavaScript выполняется преобразование значений из одного типа в другой. Жирным шрифтом в таблице выделены значения, соответствующие преобразованиям, которые могут преподносить сюрпризы. Пустые ячейки соответствуют ситуациям, когда преобразование не требуется и не выполняется.
Преобразования одного простого типа в другой, показанные в табл. 3.2, выполняются относительно просто. Преобразование в логический тип уже обсуждалось в разделе 3.3. Преобразование всех простых типов в строку четко определено. Преобразование в число выполняется немного сложнее. Строки, которые могут быть преобразованы в числа, преобразуются в числа. В строке допускается наличие пробельных символов в начале и в конце, но присутствие других непробельных символов, которые не могут быть частью числа, при преобразовании строки в число приводят к возврату значения
<b>NaN</b><b>true</b><b>false</b>Преобразование простых типов в объекты также выполняется достаточно просто: значения простых типов преобразуются в соответствующие объекты-обертки (раздел 3.6), как если бы вызывался конструктор
<b>String(), Number()</b><b>Boolean()</b>Преобразование объектов в простые типы выполняется значительно сложнее и является темой обсуждения раздела 3.8.3.

3.8.1. Преобразования и равенство
Благодаря гибкости преобразований типов в JavaScript оператор равенства == также гибко определяет равенство значений. Например, все следующие сравнения возвращают true:
<b>null == undefined // Эти два значения считаются равными.</b><b>"0" == 0 // Перед сравнением строка преобразуется в число.</b><b>0 == false // Перед сравнением логич. значение преобразуется в число.</b><b>"0" == false // Перед сравнением оба операнда преобразуются в числа.</b>В разделе 4.9.1 четко описывается, какие преобразования выполняет оператор
<b>==</b><b>===</b>Имейте в виду, что возможность преобразования одного значения в другое не означает равенства этих двух значений. Если, например, в логическом контексте используется значение
<b>undefined</b><b>false</b><b>undefined == false</b><b>if</b><b>undefined</b><b>false</b><b>==</b>3.8.2. Явные преобразования
Несмотря на то что многие преобразования типов JavaScript выполняет автоматически, иногда может оказаться необходимым выполнить преобразование явно или окажется предпочтительным выполнить явное преобразование, чтобы обеспечить ясность программного кода.
Простейший способ выполнить преобразование типа явно заключается в использовании функций
<b>Boolean(), Number(), String()</b><b>Object().</b><b>new</b><b>Number("3") // => 3</b><b>String(false) // => "false" или можно использовать false.toString()</b><b>Boolean([]) // => true</b><b>Object(3) // => new Number(3)</b>Обратите внимание, что все значения, кроме
<b>null</b><b>undefined</b><b>toString()</b><b>String()</b><b>null</b><b>undefined</b><b>ТуреЕrror</b><b>Object()</b>