zoukankan      html  css  js  c++  java
  • jQuery下通过$.browser来判断浏览器

    使用方法: 
    $.browser.['浏览器关键字'] 

    代码如下:

    $(function() { 
    if($.browser.msie) { 
    alert("this is msie"); 

    else if($.browser.safari) 

    alert("this is safari!"); 

    else if($.browser.mozilla) 

    alert("this is mozilla!"); 

    else if($.browser.opera) { 
    alert("this is opera"); 

    else { 
    alert("i don't konw!"); 


    我们看下jQuery的源码: 

    代码如下:

    var userAgent = navigator.userAgent.toLowerCase(); 
    // Figure out what browser is being used 
    jQuery.browser = { 
    version: (userAgent.match( /.+(?:rv|it|ra|ie)[/: ]([d.]+)/ ) || [])[1], 
    safari: /webkit/.test( userAgent ), 
    opera: /opera/.test( userAgent ), 
    msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ), 
    mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent ) 
    }; 


    jQuery 使用的是通过正则来匹配userAgent判断浏览器的种类和版本. 
    如果我们要来判断当前浏览器是否是IE6应该如何来判断? 
    $.browser.msie&&($.browser.version == "6.0")&&!$.support.style 
    同样jQuery判断浏览器是否为IE7 
    $.browser.msie&&($.browser.version == "7.0") 
    如果不考虑向后兼容性,又不想为了判断各浏览器类型而导入jQuery 
    判断IE最简单的方法是 

    代码如下:

    if(document.all){ 
    alert("IE6") 


    $.browser是通过正则表达式来匹配userAgent来判断浏览器版本和种类的.jquery1.3.2版本的文档中已经声明jquery.browser及jquery.browser.version建议弃用,可以使用jquery.support来代替 
    但是目前的情况来看,jquery.support并不好用,而且是非常的难用,我们还是老老实实的用$.browser来判断浏览器类型吧 
    如果是为了判断IE的版本我还是推荐用IE的条件表达式来书写JS 

    代码如下:

    <!--[if IE]> 
    <script type="text/javascript"> 
    alert("ie") 
    </script> 
    <![endif]--> 
    <!--[if IE 6]> 
    <script type="text/javascript"> 
    alert("ie6") 
    </script> 
    <![endif]--> 
    <!--[if IE 7]> 
    <script type="text/javascript"> 
    alert("ie7") 
    </script> 
    <![endif]--> 


    这个比我们手动通过$.browser来判断IE版本更精准,也不用去记jquery的browser的使用方法了

  • 相关阅读:
    IE浏览器不能启动,双击启动图标无效
    提示Internet Explorer 9 已安装在此系统上,无法完成安装
    React项目跨域处理(两种方案)
    Mock数据模拟Node服务器
    【LeetCode】15. 3Sum
    【C++】int与string互转
    【LeetCode】37. Sudoku Solver
    【LeetCode】149. Max Points on a Line
    【LeetCode】104. Maximum Depth of Binary Tree (2 solutions)
    【LeetCode】140. Word Break II
  • 原文地址:https://www.cnblogs.com/mixzo/p/4213665.html
Copyright © 2011-2022 走看看