Browser Detection
Давайте попробуем найти самый оптимальный способ определения браузеров :cool:
Рассмотрев несколько примеров из известных фреймворков и основываясь на собственном опыте написал такой код: var browser = function() { var ua = navigator.userAgent, gecko = /Gecko\//.test(ua) ? ua.match(/; rv:1\.(\d+?)\.(\d)/) : 0, webkit = /AppleWebKit/.test(ua), safari = webkit && /Safari\//.test(ua), ie = 0 /*@cc_on + @_jscript_version * 10 % 10 @*/; return { ie: ie >= 5 ? ie : 0, gecko: gecko ? '1.' + gecko.slice(1).join('.') : 0, firefox: gecko ? (gecko[1] == 9 ? 3 : gecko[1] == 8 && gecko[2] > 0 ? 2 : 0) : 0, opera: window.opera && opera.version ? opera.version()[0] : 0, webkit: webkit ? ua.match(/AppleWebKit\/(\d+?\.\d+?\s)/)[1] : 0, safari: safari && /Version\//.test(ua) ? ua.match(/Version\/(\d{1})/)[1] : 0, chrome: safari && /Chrome\//.test(ua) ? ua.match(/Chrome\/(\d+?\.\d)/)[1] : 0 }; }(); Здесь при использовании IE5.01 и ниже атрибут browser.ie будет равен 0, потому что врятле уже кто-то будет писать код для IE5.01 без использования apply. В результате выполнения этого кода в FF3.0.3 получается вот такой объект: browser = { ie:0, gecko:"1.9.0", firefox:3, opera:0, webkit:0, safari:0, chrome:0 }; Какие у Вас есть предложения по улучшению кода? Может быть кто-то знает более короткие или быстрые способы узнать, какой браузер используется? Какие браузеры стоит добавить в список, а какие убрать? И т.д. и т.п. Так же будет интересно, если кто-то сможет протестировать код в разных версиях Safari. |
Цитата:
Такое "определение браузера/версии" можно назвать условным, без гарантий. Любое изменение строк производителем UA или пользователем, любое изменение особенностей движка может привести к проблемам. Из недавних... Если пару слов навскидку по скрипту, то вы смешиваете "главные" строки со "второстепенными". Например, если мы нашли 'gecko', но по каким-то причинам не нашли номер версии, то браузер не определится вообще. Или, определив объект 'opera', мы можем не определить 'version', т.к. первый старше второго версий на несколько, браузер снова не определится. Значением 'version' является строка, возможность применить к строке ака массивное обращение '[0]' - это экстеншн, вне рамок стандарта. Определяя IE, можно было бы просто сравнить номер полученной версии с чем-то, не обязательно множить на десять и ловить хвостик. Чем черт не шутит, возможно MS начнёт очень быстро менять версии jscript.dll и в недалёком будущем (IE8+) нам засветит версия 6.0+, ваш скрипт в этом случае споткнётся. И вообще, номер версии jscript не обязательно говорит о версии браузера, 5.7 встречается и на IE<7 (разные либы с одним номером). Ну, и надо как-то размыкать возможную двойственность, к примеру, у меня в Опере что 'browser.gecko=',что 'browser.opera=' выдают номера версий, т.к. Опера представляется фоксом и меня, как пользователя, это совершенно не волнует... |
Спасибо за полезные ссылки.
Цитата:
По поводу работы со строкой «userAgent». John Resing к примеру, в своём блоге советует не использовать object detection (if(window.opera) {…}), а определять браузер именно по «userAgent». Поэтому тут спорный момент, является ли изменение пользователем строки «userAgent» его проблемой или программист должен предусмотреть эту возможность? По поводу определения версии IE — это самый короткий и стабильный способ определения Internet Explorer, известный мне. В Internet Explorer 8 вроде бы уже известно, что версия JScript будет 5.8. Так, что у нас в запасе ещё есть 5.9, а когда JScript дорастет до 6.0 ещё не известно нужен ли будет подобный скрипт вообще, да и то что есть сейчас не трудно исправить. Постараюсь разобраться в приведённых Вами примерах и улучшить код. |
Цитата:
Цитата:
Цитата:
p.s. ради интереса решил посмотреть, что натворил новый хромой браузер в стране кода, где определяют не фичи, а браузер. Отвалились скрипты у сайтов, которые проверяли вендора, от мелких, до таких, как, например, CNN.COM, цитирую: Цитата:
Цитата:
|
А чем
window.opera.version()плохо? Может я чего то не знаю :confused: |
Zeroglif,
Бывают ситуации, где простым object detection не обойтись, например в работе с клавиатурным вводом, где одинаковые свойства в разных браузерах имеют разные значения. Или, например, установка специфических событий, например DOMContentLoaded - просто проверить наличие addEventListener недостаточно. |
Цитата:
Цитата:
Цитата:
|
Да это я что-то увлекся, работая со строкой, как с массивом символов :-) хотя во всех современных браузерах работает, надо будет переписать через charAt.
Opera ниже версии 7.6 в принципе и не нужна, если Вы не заметили, то в моем скрипте отсекается FireFox 1.x.x. Толку от определения древнейших браузеров в современном скрипте практически никаких, напичканный всякими apply и XMLHttpRequest он в любом случае не заработает в старом браузере. Не все браузеры поддерживающие addEventListener обрабатывают событие DOMContentLoaded, поэтому в этом случае object detection бессилен. |
Цитата:
|
Цитата:
|
Часовой пояс GMT +3, время: 20:59. |