Хорошо, я снова добавлю этот ответ, даже если он не мой, и добавлю некоторую информацию, чтобы вы могли чувствовать себя нормально, принимая его, даже если это не был мой ответ с самого начала.
Итак, предлагаемый код такой:
var key;
e = e || window.event;
key = e.keyCode || e.which;
Что делает ||
? С одной стороны, это логический оператор или оператор, который возвращает true, если одна из сторон оценивает как boolean true.
Он также используется в JS. Если вы дадите ему два аргумента, а первый не определен, он вернет второй аргумент. Это означает, что в приведенном выше коде, если e
не определено, вместо этого вы получите window.event
, который является традиционным объектом события IE.
То же самое относится и к e.keyCode || e.which
, какой бы ни существовал, используется. Таким образом, в конечном итоге вы получите правильный код ключа в различных браузерах. В стране чудес все хорошо.
Но подождите, ваш оригинальный код не делает что-то подобное?
var key = (window.Event) ? e.which : e.keyCode;
Угу. Что это такое? JavaScript чувствителен к регистру, поэтому window.Event
означает , а не так же, как window.event
в приведенном выше коде. window.event
- это традиционный объект события IE, который вы бы использовали для получения информации о произошедшем событии, в то время как window.Event
(который вы можете увидеть из начальной заглавной буквы) является конструктором, или, более конкретно, в данном случае интерфейсом .
Дело в том, что в этом коде он использовался для обнаружения Mozilla. Если он существует, выберите e.which
(одно из мест, где Mozilla хранит код ключа), в противном случае перейдите к e.keyCode
, где IE будет хранить код ключа.
Однако это основано на ошибочном предположении, что IE не имеет определенного конструктора window.Event
. По крайней мере, он определен как IE8. Это означает, что e.which
выбирается вместо e.keyCode
в более новых версиях IE. e.which
никогда и никогда не будет поддерживаться в IE. Вот почему key
оказывается неопределенным.
Но, хм, почему они отличаются между зашифрованными и незашифрованными соединениями? Это хороший вопрос. Хотя я не могу знать наверняка без доступа к вашей среде разработки, я бы предположил, что она имеет что-то с режимами совместимости IE.
IE исторически (за последние 10 лет) был самым необычным и нестандартным браузером во всем мире. Это привело к тому, что люди а) программировали невежественно в соответствии со стандартами IE, б) создавали обходные пути для поведения IE. Если бы MS просто сделала IE совместимым со стандартами, это сломало бы много страниц, которые так или иначе зависят от странного поведения IE. Microsoft подтвердила это, заставив IE8 + эмулировать более старые версии IE, чтобы страницы не ломались, если не указано иное.
Я могу только предположить, что по какой-то причине в вашей тестовой среде страница в конечном итоге будет работать в режиме "IE7", в котором может не быть определен конструктор / интерфейс window.Event
. Это заставит ваш старый код использовать e.keyCode
, что в порядке. Тогда, возможно, в вашей производственной среде, или, может быть, просто из-за зашифрованного соединения (только ghawd знает, что делает MS), вы получите более новый режим IE, так что window.Event
фактически определено и e.which
выбрано. Это делает IE нахальной обезьяной.
Итог: используйте новый код.