zoukankan      html  css  js  c++  java
  • 使用 navigator.userAgent.toLowerCase() 区别 浏览器 类型

    userAgent 属性是一个只读的字符串,声明了浏览器用于 HTTP 请求的用户代理头的值

    var ua = navigator.userAgent.toLowerCase();

    返回的是个字符串

    观察几个软件:

    (1)iphone ,夸克浏览器

    (2)iphone ,QQ浏览器

     (3)iphone ,QQ内置浏览器

     (4)iphone ,微信 内置浏览器

     (5)iphone ,搜狗浏览器

    //////

    /////下面的是安卓的

    (6) android ,QQ浏览器

     (7)android,微信 内置浏览器

     。。。。

    其他的就不找了,每个浏览器都有自己独特的 字符,不同系统也是一样,包括pc

    下面是用来区分不同系统的不同浏览器的啊操作源码

    识别源码模板:

     1 /**
     2  * 经过测试,iphone 手机 的QQ浏览器和QQ内置浏览器,无法连接websocket
     3  * 因此这个文件功能是不允许他们访问本网页
     4  *
     5  */
     6 
     7 
     8 //获取浏览器用于 HTTP 请求的用户代理头的值
     9 var ua = navigator.userAgent.toLowerCase();
    10 var canUse =true ,reason = "";
    11 // alert(ua);
    12 // isWx = false,isQQ = false, isQQInstalled = false;
    13 function BrowserCompatible() {
    14     //有 qq 关键字 且不存在 mqqbrowser 关键字 则为QQ内置浏览器
    15     if (ua.indexOf(' qq') > -1 && ua.indexOf('mqqbrowser') < 0 && ua.indexOf('micromessenger') < 0) {
    16         //qq内置浏览器
    17         // isQQInstalled = true;
    18         if (ua.indexOf('iphone')){
    19             //iphone 手机
    20             canUse = false;
    21             reason = "苹果手机 qq内置浏览器,禁止访问,请使用微信或Safari";
    22             alert(reason);
    23             window.close();
    24         }
    25         return;
    26     }
    27     //
    28     if (ua.indexOf('mqqbrowser') > -1 && ua.indexOf(" qq") < 0  && ua.indexOf('micromessenger') < 0) {
    29         //qq浏览器
    30         // isQQ = true;
    31         if (ua.indexOf('iphone')){
    32             //iphone 手机
    33             canUse = false;
    34             reason = "苹果手机 qq浏览器,禁止访问,请使用微信或Safari";
    35             alert(reason);
    36             window.close();
    37         }
    38         return;
    39     }
    40     // if (ua.match(/MicroMessenger/i) == 'micromessenger') {
    41     if (ua.indexOf('micromessenger') > -1) {
    42         //微信浏览器
    43         // isWx = true;
    44         if (ua.indexOf('iphone')){
    45             //iphone 手机
    46             alert("苹果手机 微信内置浏览器");
    47             window.close();
    48         }
    49         return;
    50     }
    51     alert("其他")
    52 }
    53 
    54 BrowserCompatible();
  • 相关阅读:
    [NPM] Avoid Duplicate Commands by Calling one NPM Script from Another
    [Algorithm] Dynamic programming: Find Sets Of Numbers That Add Up To 16
    [React] Refactor a Class Component with React hooks to a Function
    [Algorithm] Construct a Binary Tree and Binary Search
    设计模式(装饰者模式)
    IOS设计模式之二(门面模式,装饰器模式)
    IOS设计模式之三(适配器模式,观察者模式)
    linux内核源码阅读之facebook硬盘加速flashcache之五
    IOS设计模式之四(备忘录模式,命令模式)
    DRP总结
  • 原文地址:https://www.cnblogs.com/c2g5201314/p/12315604.html
Copyright © 2011-2022 走看看