Чтение онлайн

ЖАНРЫ

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

На практике необходимость проверять свойство

compatMode
возникает редко. Тем не менее в примере 15.8 демонстрируется один из случаев, когда эта проверка действительно необходима.

13.4.5. Проверка типа броузера

Методика проверки особенностей прекрасно подходит для определения поддерживаемых функциональных возможностей броузера. Ее можно использовать, например, чтобы выяснить, какая модель обработки событий поддерживается, W3C или IE. В то же время иногда может потребоваться обойти те или иные ошибки, свойственные конкретному типу броузеров, когда нет достаточно простого способа определить наличие этих ошибок. В этом случае бывает необходимо разработать программный

код, который должен выполняться только в броузерах определенного производителя, определенного номера версии или в конкретной операционной системе (либо в некоторой комбинации всех трех признаков).

На стороне клиента сделать это можно с помощью объекта Navigator, о котором рассказывается в главе 14. Программный код, который определяет производителя и версию броузера, часто называют анализатором броузера (<browser sniffer) или анализатором клиента (<client sniffer). Простой анализатор такого типа приводится в примере 14.3. Методика определения типа клиента широко использовалась на ранних этапах развития Всемирной паутины, когда Netscape и 1Б имели серьезные отличия и были несовместимы. Ныне ситуация с совместимостью стабилизировалась, и анализ типа клиента утратил свою актуальность и проводится лишь в тех случаях, когда это действительно необходимо.

Примечательно, что определение типа клиента может быть выполнено также на стороне сервера, благодаря чему веб-сервер на основе строки идентификации броузера, которая передается серверу в заголовке User-Agent, может выяснить, какой JavaScript-код требуется отсылать.

13.4.6. Условные комментарии в Internet Explorer

На практике вы можете обнаружить, что большинство несовместимостей, которые необходимо учитывать при разработке клиентских сценариев, обусловлены спецификой броузера IE. Вследствие этого иногда возникает необходимость создавать программный код отдельно для IE и отдельно для всех остальных броузеров. Броузер IE поддерживает нестандартную возможность создания условных комментариев (эта возможность появилась в IE5) в JavaScript-коде, что может оказаться полезным для решения проблем несовместимости.

В следующем примере демонстрируется, как выглядят условные комментарии в HTML. Примечательно, что вся хитрость заключается в комбинации символов, закрывающих комментарий.

<!—[if IE 6]>

Эти строки фактически находятся внутри HTML-комментария.

Они будут отображаться только в IE6.

<![endif]-->

<!—[if lte IE 7]>

Эта строка будет отображена только в IE 5. 6, 7 и в более ранних версиях.

lte обозначает "less than or equal" (меньше или равно). Можно также использовать "It”,

"gt" и "gte”.

<![endif]-->

<! —[if ! IE]> <->

Это обычное HTML-содержимое, но IE не будет отображать его из-за комментариев, что расположены выше и ниже.

<!--> <![endif]-->

Это обычное содержимое, которое будет отображаться всеми броузерами.

В качестве более конкретного примера возьмем библиотеку excanvas.js, о которой выше говорилось, что она реализует поддержку элемента

<canvas>
в Internet Explorer. Поскольку эта библиотека требуется, только когда веб-страница отображается в IE (и работает только в IE), есть смысл оформлять ее подключение внутри условного комментария, чтобы другие броузеры даже не загружали
ее:

<!--[if IE]><script src="excanvas.js"></script><![endif]-->

Условные комментарии также поддерживаются интерпретатором JavaScript в IE. Программисты, знакомые с языком C/C++, найдут их похожими на инструкции препроцессора

#ifdef/#endif
. Условные JavaScript-комментарии в IE начинаются с комбинации символов
/*@сс_оп
и завершаются комбинацией
@*/
. (Префиксы «сс» и «сс_оп» происходят от фразы «condition compilation», т. е. «условная компиляция».) Следующий условный комментарий содержит программный код, который будет выполняться только в IE:

/*@сс_оn

@if (@_jscript)

// Следующий код находится внутри JS-комментария, но IE выполнит его.

alert("In IE”);

@end

@*/

Внутри условных комментариев могут указываться ключевые слова

@if
,
@else
и
@end
, предназначенные для отделения программного кода, который должен выполняться интерпретатором JavaScript в IE по определенному условию. В большинстве случаев вам достаточно будет использовать показанное в предыдущем фрагменте условие
@if (@_jscript).
JScript
– это название интерпретатора JavaScript, которое было дано ему в Microsoft, а переменная
@_jscript
в IE всегда имеет значение
true
.

При грамотном чередовании условных и обычных JavaScript-комментариев можно определить, какой блок программного кода должен выполняться в IE, а какой -во всех остальных броузерах:

/*@сс_оп

@if (@_jscript)

// Этот блок кода находится внутри условного комментария,

// который также является обычным JavaScript-комментарием.

// В IE этот блок будет выполнен, а в других броузерах - нет.

alert('Bы пользуетесь Internet Explorer');

@else*/

// Этот блок уже не находится внутри JavaScript-комментария,

// но по-прежнему находится внутри условного комментария IE.

// Вследствие этого данный блок кода будет выполнен всеми броузерами, кроме IE.

alert(*Bы не пользуетесь Internet Explorer');

/*@end

@*/

13.5. Доступность

Всемирная паутина представляет собой замечательный инструмент распространения информации, и JavaScript-сценарии могут сделать эту информацию максимально доступной. Однако JavaScript-программисты должны проявлять осторожность: слишком просто написать такой JavaScript-код, который сделает невозможным восприятие информации для пользователей с ограниченными возможностями.

Поделиться с друзьями: