javaScript用户代理检测(检测所在平台 PC还是安卓还是IOS)

之前面试的时候被面试官用怎么检测所在平台问倒,今天参照JS高级程序设计里面9.3的内容仿写了程序下面上程序吧 可以直接用来检测

  //这是整个对象 放到自己里面直接调用参数就好了
  var clienet = function(){
  	//呈现引擎
  	var engine = {
  		ie: 0,
  		gecko:0,
  		webkit:0,
  		khtml:0,
  		opera:0,
  		//完整的版本号
  		ver:null
  	};

  	//浏览器
  	var browser = {
  		//主要浏览器
  		ie:0,
  		firefox: 0,
  		safari: 0,
  		konq: 0,
  		opera: 0,
  		chrome: 0,
  		//具体版本号
  		ver:null
  	};

  	//平台,设备和操作系统
  	var system = {
  		win : false,
  		mac : false,
  		x11 : false,

  		//移动设备
  		iphone: false,
  		ipod : false,
  		ipad : false,
  		ios : false,
  		android : false,
  		nokiaN: false,
  		winMobile : false,

  		//游戏系统
  		wii : false,
  		ps : false
  	};

  	//检测呈现引擎和浏览器
  	var ua = navigator.userAgent;
  	if(window.opera){
  		engine.ver = browser.ver = window.opera.version();
  		engine.opera = browser.opera =parseFloat(engine.ver);
  	} else if(/AppleWebKit\/(\S+)/.test(ua)){
  		engine.ver  = RegExp["$1"];
  		engine.webkit = parseFloat(engine.ver);

  		//确定时Chorme还是Safari
  		if(/Chrome\/(\S+)/.test(ua)){
  			browser.ver = RegExp["$1"];
  			browser.chrome = parseFloat(engine.ver);
  		} else if (/Version\/(\S+)/.test(ua)){
  			browser.ver = RegExp["$1"];
  			browser.safari = parseFloat(engine.ver);
  		} else {
  			var safariVersion = 1;
  			if(engine.webkit < 100){
  				safariVersion = 1;
  			} else if(engine.webkit < 312){
  				safariVersion = 1.2;
  			} else if(engine.webkit < 412){
  				safariVersion = 1.3;
  			} else {
  				safariVersion = 2;
  			}
  			browser.safari = browser.ver = safariVersion;
  		}
  	} else if(/KHTML\/(\S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)){
  		engine.ver = browser.ver = RegExp["$1"];
  		engine.ktml = browser.konq =parseFloat(engine.ver);
  	} else if(/rv:([^\)]+)\)Gecko\/d{8}/.test(ua)){
  		engine.ver = RegExp["$1"];
  		engine.gecko = parseFloat(engine.ver);

  		//确定是不是Firefox
  		if(/Firefox\/(\S+)/.test(ua)){
  			browser.ver = RegExp["$1"];
  			browser.firefox = parseFloat(engine.ver);
  		}
  	} else if(/MSIE([^;]+)/.test(ua)){
  		engine.ver = browser.ver = RegExp["$1"];
  		engine.ie = browser.ie =parseFloat(engine.ver);
  	}

  	//检测浏览器
  	browser.ie = engine.ie;
  	browser.opera = engine.opera;

  	//检测平台
  	var p = navigator.platform;
  	system.win = p.indexOf("win") == 0;
  	system.mac = p.indexOf("mac") == 0;
  	system.x11 = (p == "X11") || (p.indexOf("Linux") == 0);

  	//检测Windows操作系统
  	if(system.win){
  		if(/Win(?:dows)?([^do]{2})\s?(\d+\.\d+)?/.test(ua)){
  			if(RegExp["$1"] == "NT"){
  				switch(RegExp["$2"]){
  					case "5.0" :
  						system.win = "2000";
  						break;
  					case "5.1" :
  						system.win = "XP";
  						break;
  					case "6.0" :
  						system.win = "Vista";
  						break;
  					case "6.1" :
  						system.win = "7";
  						break;
  					default:
  						system.win = "NT";
  						break;
  				}
  			} else if(RegExp["$1"] == "9x"){
  				system.win = "ME";
  			} else {
  				system.win = RegExp["$1"];
  			}
  		}
  	}
  	system.iphone = ua.indexOf("iPhone") > -1;
  	system.ipod = ua.indexOf("iPod") > -1;
  	system.ipad = ua.indexOf("iPad") > -1;
  	system.nokiaN = ua.indexOf("NokiaN") > -1;

  	//windows mobile
  	if(system.win == "CE"){
  		system.winMobile = system.win;
  	} else if(system.win == "Ph"){
  		if(/Windows Phone OS (\d+.\d+)/.test(ua)){
  			system.win = "Phone";
  			system.winMobile = parseFloat(RegExp["$1"]);
  		}
  	}

  	//检测ios版本
  	if(system.MAC && UA.indexOf("Mobile") > -1){
  		if(/cpu (?:iPhone )?OS (\d+.\d+)/.test(ua)){
  			system.ios = parseFloat(RegExp.$1.replace("_","."));
  		} else {
  			system.ios = 2;
  		}
  	}

  	//检测Android版本
  	if(/Android (\d+.\d+)/.test(ua)){
  		system.android = parseFloat(RegExp.$1);
  	}

  	//游戏系统
  	system.wii = ua.indexOf("Wii") > -1;
  	system.ps = /playstation/i.test(ua);

  	return {
  		engine:engine,
  		browser:browser,
  		system:system
  	};

  }();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值