JavaScript判断浏览器类型及版本

     最近在写导出EXCEL时遇到了IE8在执行window.open(url,"_black","")时,发现页面一闪就关掉了,查了资料总结了下如何获取浏览器类型及版本信息,就可以根据不同浏览器和版本实现更好的兼容

     除了我们熟知的IE, Firefox, Opera, Safari四大浏览器之外,世界上还有近百种浏览器。

     JavaScript是前端开发的主要语言,我们可以通过编写JavaScript程序来判断浏览器的类型及版本。JavaScript判断浏览器类型一般有两种办法,一种是根据各种浏览器独有的属性来分辨,另一种是通过分析浏览器的userAgent属性来判断的。在许多情况下,值判断出浏览器类型之后,还需判断浏览器版本才能处理兼容性问题,而判断浏览器的版本一般只能通过分析浏览器的userAgent才能知道。

     IE

     只有IE支持创建ActiveX控件,因此她有一个其他浏览器没有的东西,就是ActiveXObject函数。只要判断window对象存在ActiveXObject函数,就可以明确判断出当前浏览器是IE。(注意了,如果你使用脚本语言来编程一些功能时,在其他浏览器发现却不能使用,就要检查下当初的编码是不是基于某一特定浏览器了。)。而IE各个版本典型的userAgent如下:

     Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0)
     Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2)
     Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)
     Mozilla/4.0 (compatible; MSIE 5.0; Windows NT)

其中,版本号是MSIE之后的数字。

       Firefox

       Firefox中的DOM元素都有一个getBoxObjectFor函数,用来获取该DOM元素的位置和大小(IE对应的中是getBoundingClientRect函数)。这是Firefox独有的,判断它即可知道是当前浏览器是Firefox。Firefox几个版本的userAgent大致如下:

        Mozilla/5.0 (Windows; U; Windows NT 5.2) Gecko/2008070208 Firefox/3.0.1
        Mozilla/5.0 (Windows; U; Windows NT 5.1) Gecko/20070309 Firefox/2.0.0.3
        Mozilla/5.0 (Windows; U; Windows NT 5.1) Gecko/20070803 Firefox/1.5.0.12

      其中,版本号是Firefox之后的数字。

     Opera

        Opera提供了专门的浏览器标志,就是window.opera属性。Opera典型的userAgent如下: 
        Opera/9.27 (Windows NT 5.2; U; zh-cn)
        Opera/8.0 (Macintosh; PPC Mac OS X; U; en)
        Mozilla/5.0 (Macintosh; PPC Mac OS X; U; en) Opera 8.0
其中,版本号是靠近Opera的数字。

  Safari

       Safari浏览器中有一个其他浏览器没有的openDatabase函数,可做为判断Safari的标志。Safari典型的userAgent如下:

        Mozilla/5.0 (Windows; U; Windows NT 5.2) AppleWebKit/525.13 (KHTML, like Gecko) Version/3.1 Safari/525.13
        Mozilla/5.0 (iPhone; U; CPU like Mac OS X) AppleWebKit/420.1 (KHTML, like Gecko) Version/3.0 Mobile/4A93 Safari/419.3

      其版本号是Version之后的数字。

 Chrome

      Chrome有一个MessageEvent函数,但Firefox也有。不过,好在Chrome并没有Firefox的getBoxObjectFor函数,根据这个条件还是可以准确判断出Chrome浏览器的。目前,Chrome的userAgent是: 
  Mozilla/5.0 (Windows; U; Windows NT 5.2) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.27 Safari/525.13

      其中,版本号在Chrome只后的数字。

      有趣的是,Chrome的userAgent还包含了Safari的特征,也许这就是Chrome可以运行所有Apple浏览器应用的基础吧。

      只要了解了以上信息,我们就可以根基这些特征来判断浏览器类型及其版本了。我们会将判断的结果保存在Sys名字空间中,成为前端框架的基本标志信息,供今后的程序来读取。如果判断出谋种浏览器,Sys名字空间将有一个该浏览器名称的属性,其值为该浏览器的版本号。例如,如果判断出IE 7.0,则Sys.ie的值为7.0;如果判断出Firefox 3.0,则Sys.firefox的值为3.0。下面是判断浏览器的代码:

 

<script type="text/javascript">

        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];

       

        //以下进行测试

        if(Sys.ie) document.write('IE: '+Sys.ie);

        if(Sys.firefox) document.write('Firefox: '+Sys.firefox);

        if(Sys.chrome) document.write('Chrome: '+Sys.chrome);

        if(Sys.opera) document.write('Opera: '+Sys.opera);

        if(Sys.safari) document.write('Safari: '+Sys.safari);


    </script>

 

下面的代码采用三目运算符的方式来写判断浏览器类型和版本的方式:

<script type="text/javascript">

        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) document.write('IE: ' + Sys.ie);

        if (Sys.firefox) document.write('Firefox: ' + Sys.firefox);

        if (Sys.chrome) document.write('Chrome: ' + Sys.chrome);

        if (Sys.opera) document.write('Opera: ' + Sys.opera);

        if (Sys.safari) document.write('Safari: ' + Sys.safari);

    </script>

 

采用了“... ? ... : ...”这样的判断表达式来精简代码。判断条件是一条赋值语句,既完成正则表达式的匹配及结果复制,又直接作为条件判断。而随后的版本信息只需从前面的匹配结果中提取即可,这是非常高效的代码。

 

总结一下针对IE平时经常用的到的一些方式方法有下面的几种,其实方法都是和上面的原理一样的:

1、判断浏览器是否为IE
        document.all ? 'IE' : 'others':在IE下document.all值为1,而其他浏览器下的值为0;
        navigator.userAgent.indexOf("MSIE")>0 ? 'IE' : 'others':navigator.userAgent是描述用户代理信息。
        navigator.appName.indexOf("Microsoft") != -1 ? 'IE' : 'others':navigator.appName描述浏览器名称信息。

2、判断IE版本
        navigator.appVersion.match(/6./i)=="6." ? 'IE6' : 'other version':在已知是IE浏览器的情况下,可以通过此方法判断是否是IE6;
        navigator.userAgent.indexOf("MSIE 6.0")>0 ? 'IE7' : 'other version':同上;
        navigator.appVersion.match(/7./i)=="7." ? 'IE7' : 'other version':在已知是IE浏览器的情况下,可以通过此方法判断是否是IE7;
        navigator.userAgent.indexOf("MSIE 7.0")>0 ? 'IE7' : 'other version':同上;
        navigator.appVersion.match(/8./i)=="8." ? 'IE8' : 'other version':在已知是IE浏览器的情况下,可以通过此方法判断是否是IE8;
        navigator.userAgent.indexOf("MSIE 8.0")>0 ? 'IE8' : 'other version':同上。

3、JS获取浏览器信息
        浏览器代码名称:navigator.appCodeName
        浏览器名称:navigator.appName
        浏览器版本号:navigator.appVersion
        对Java的支持:navigator.javaEnabled()
        MIME类型(数组):navigator.mimeTypes
        系统平台:navigator.platform
        插件(数组):navigator.plugins
        用户代理:navigator.userAgent

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScript不能直接判断浏览器是否允许下载文件,但是可以通过尝试下载文件并监听下载过程的错误事件来间接判断。 以下是一个示例代码: ``` var link = document.createElement('a'); link.style.display = 'none'; link.href = 'example.pdf'; link.download = 'example.pdf'; document.body.appendChild(link); link.addEventListener('error', function() { console.log('浏览器不允许下载文件'); }); link.click(); document.body.removeChild(link); ``` 在上面的代码中,我们创建了一个隐藏的 `a` 元素,并设置了它的 `href` 和 `download` 属性。然后将其添加到文档中并进行点击。如果浏览器不允许下载文件,则会触发错误事件,在回调函数中可以打印错误消息。 ### 回答2: 在JavaScript中,可以使用浏览器的`navigator`对象来判断是否允许下载文件。具体的方法如下: ```javascript // 检查浏览器是否允许下载文件 function isFileDownloadAllowed() { // 判断是否支持Blob对象 if (typeof window.Blob == 'undefined') { return false; } // 创建一个Blob对象,尝试下载 try { var blob = new Blob(['test'], { type: 'text/plain' }); if (window.navigator.msSaveBlob) { // 如果是IE浏览器,使用msSaveBlob方法 window.navigator.msSaveBlob(blob, 'test.txt'); } else { // 如果是其他浏览器,创建一个下载链接并点击 var link = document.createElement('a'); link.href = URL.createObjectURL(blob); link.download = 'test.txt'; link.click(); } return true; } catch (e) { console.error(e); return false; } } ``` 上述代码中,我们首先通过判断`typeof window.Blob`来检查浏览器是否支持Blob对象。然后,我们尝试创建一个Blob对象并尝试下载一个简单的文本文件。对于IE浏览器,我们使用`window.navigator.msSaveBlob`方法进行下载,对于其他浏览器,我们创建一个下载链接并模拟点击链接来进行下载。如果在此过程中出现任何错误,我们会在控制台输出错误信息,并返回`false`表示浏览器不允许下载文件。如果没有出现错误,返回`true`表示浏览器允许下载文件。 请注意,在某些情况下,浏览器可能会阻止自动下载文件,例如当浏览器的弹出窗口阻止程序调用浏览器的下载功能时。使用以上代码,并不一定能够100%准确判断浏览器是否允许下载文件,但可以作为一个初步的判断依据。 ### 回答3: 要判断浏览器是否允许下载文件,可以通过JavaScript中的浏览器对象属性进行判断。 首先,可以使用navigator对象的mimeTypes属性来检查浏览器是否支持指定的MIME类型。MIME类型是用于标识文件类型的一种方法。可以使用以下代码来判断浏览器是否支持下载: ```javascript function isDownloadSupported() { var mimeTypes = navigator.mimeTypes; var mimeType = 'application/octet-stream'; // 可以根据实际需要使用其他MIME类型 return mimeTypes && mimeTypes[mimeType] && mimeTypes[mimeType].enabledPlugin; } ``` 上述代码中,首先获取了当前浏览器的mimeTypes属性,然后通过指定的MIME类型来检查是否支持。如果支持,那么mimeTypes[mimeType]返回一个包含enabledPlugin属性的对象;如果不支持,则返回undefined。如果enabledPlugin属性存在且为真,则说明浏览器允许下载文件。 另外,还可以使用以下代码来检查浏览器是否支持下载: ```javascript function isDownloadSupported() { var a = document.createElement('a'); return typeof a.download !== 'undefined'; } ``` 上述代码中,通过创建一个<a>元素,并检查其是否具有download属性来判断浏览器是否允许下载文件。如果download属性存在,则说明浏览器允许下载。 需要注意的是,不同浏览器浏览器版本可能对下载的支持程度不同,因此以上方法可能无法覆盖所有情况。在实际使用中,建议结合其他方法进行判断,以确保在不同环境下的兼容性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值