Navigator 对象包含有关浏览器的信息:
•appCodeName -- 浏览器代码名的字符串表示
•appName -- 官方浏览器名的字符串表示
•appVersion -- 浏览器版本信息的字符串表示
•cookieEnabled -- 如果启用cookie返回true,否则返回false
•javaEnabled -- 如果启用java返回true,否则返回false
•platform -- 浏览器所在计算机平台的字符串表示
•plugins -- 安装在浏览器中的插件数组
•taintEnabled -- 如果启用了数据污点返回true,否则返回false
•userAgent -- 用户代理头的字符串表示
navigator中最重要的是userAgent属性,返回包含浏览器版本等信息的字符串;
cookieEnabled也很重要,使用它可以判断用户浏览器是否开启cookie。
javaScript判断浏览器类型一般有两种办法,一种是根据各种浏览器独有的属性来分辨,另一种是通过分析浏览器的userAgent属性来判断(版本只能通过分析userAgent获得);
只有在浏览器类型 和 浏览器版本都判断出后,才能处理兼容性问题。
1、通过userAgent中的特征来判断浏览器类型及版本(常用、保险做法)
function getBrowserInfo() { var Sys = {}; var ua = navigator.userAgent.toLowerCase(); var s; (s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] : (s = ua.match(/firefox\/([\d.]+)/)) ? Sys.firefox = s[1] : (s = ua.match(/chrome\/([\d.]+)/)) ? Sys.chrome = s[1] : (s = ua.match(/opera.([\d.]+)/)) ? Sys.opera = s[1] : (s = ua.match(/version\/([\d.]+).*safari/)) ? Sys.safari = s[1] : 0; if(Sys.ie) { return 'IE: ' + Sys.ie; } if(Sys.firefox) { return 'Firefox: ' + Sys.firefox; } if(Sys.chrome) { return 'Chrome: ' + Sys.chrome; } if(Sys.opera) { return 'Opera: ' + Sys.opera; } if(Sys.safari) { return 'Safari: ' + Sys.safari; } } var browser = getBrowserInfo() ; var verinfo = (browser+"").replace(/[^0-9.]/ig, ""); // 版本号
注意:一些浏览器的userAgent属性值中Chrome、Safari皆有,是因为Chrome的userAgent还包含了Safari的特征,因此这可能是Chrome可运行Safari浏览器应用的基础的原因。
2、通过各浏览器独有特性来分辨浏览器(需注意:这些特征可能会随浏览器版本而变化,或是其他浏览器也就可能跟着加入该特性,从而导致判断失败)
IE:只有IE支持创建ActiveX控件,所以ActiveXObject函数是其他浏览器没有的。只需判断window对象存在 ActiveXObject函数,就明确判断出当前浏览器是IE。
Firefox:FF中的DOM元素都有一个getBoxObjectFor函数,用来获取该DOM元素的位置和大小。这是Firefox独有的,判断它即可分辨当前浏览器是Firefox。(IE对应的中是 getBoundingClientRect函数)
Opera:Opera提供了专门的浏览器标志-- window.opera属性。
Safari:openDatabase函数是其他浏览器没有的,可做为判断Safari的标志。
Chrome:和FF一样都一个MessageEvent函数,但Chrome并没有FF的getBoxObjectFor 函数,根据这两个条件可判断Chrome浏览器。
var Sys = {}; var ua = navigator.userAgent.toLowerCase(); if(window.ActiveXObject) { Sys.ie = ua.match(/msie ([\d.]+)/)[1] }else if(document.getBoxObjectFor) { Sys.firefox = ua.match(/firefox\/([\d.]+)/)[1] }else if(window.MessageEvent && !document.getBoxObjectFor) { Sys.chrome = ua.match(/chrome\/([\d.]+)/)[1] }else if(window.opera) { Sys.opera = ua.match(/opera.([\d.]+)/)[1] }else if(window.openDatabase) { Sys.safari = ua.match(/version\/([\d.]+)/)[1]; }
水平有限,文中错误不妥在所难免,欢迎批评指正建议评论。文章将不定期修改完善斧正。谢谢!
以上这篇Js 获取、判断浏览器版本信息的简单方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍JavaScript判断浏览器及其版本信息,包括了JavaScript判断浏览器及其版本信息的使用技巧和注意事项,需要的朋友参考一下 通过window.navigator来判断: 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!
本文向大家介绍js判断浏览器版本以及浏览器内核的方法,包括了js判断浏览器版本以及浏览器内核的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js判断浏览器版本以及浏览器内核的方法。分享给大家供大家参考。具体实现方法如下: js判断是否移动端及浏览器内核 代码二 希望本文所述对大家的javascript程序设计有所帮助。
本文向大家介绍如何基于js判断浏览器版本,包括了如何基于js判断浏览器版本的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了如何基于js判断浏览器版本,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 浏览器类型判断 不考虑对 IE9 以下浏览器的判断 测试 判断IE浏览器的版本 包含edge,ie11,10,9,8,7,6,5,4 判断浏
本文向大家介绍js判断当前浏览器类型,判断IE浏览器方法,包括了js判断当前浏览器类型,判断IE浏览器方法的使用技巧和注意事项,需要的朋友参考一下 判断IE浏览器最短方法:var isIE = !-[1,] 原理:[1,]在标准浏览器中返回"1",相当于调用[1,].toString(),在IE中返回"1," 在这个时候对返回值使用负号强制转换为数字时,标准浏览器返回1,IE则返回NaN, 再对1
本文向大家介绍javascript 判断当前浏览器版本并判断ie版本,包括了javascript 判断当前浏览器版本并判断ie版本的使用技巧和注意事项,需要的朋友参考一下 javascript 判断当前浏览器版本并判断ie版本: 2、判断是什么类型浏览器 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
本文向大家介绍js判断主流浏览器类型和版本号的简单实现代码,包括了js判断主流浏览器类型和版本号的简单实现代码的使用技巧和注意事项,需要的朋友参考一下 如今的互联网中,浏览器可以说是太多太多了,但是大部分都是换壳不换心,基本上主流的浏览器还是火狐,谷歌,IE,safrai这几种比较常见,所以在我们的开发中,有时候需要遇到判断用户正在使用什么浏览器以及使用的版本是多少,并根据返回值,给予一定的提示,