Javascript中获取浏览器类型和操作系统版本等客户端信息常用代码
/**
* @author hechen
*/
var gs = {
/**获得屏幕宽度**/
ScreenWidth: function () {
return window.screen.width;
},
/***获得屏幕高度**/
ScreenHeight: function () {
return window.screen.height;
},
/**获得浏览器***/
Browse: function () {
var browser = {};
var userAgent = navigator.userAgent.toLowerCase();
var s;
(s = userAgent.match(/msie ([\d.]+)/)) ? browser.ie = s[1] : (s = userAgent.match(/firefox\/([\d.]+)/)) ? browser.firefox = s[1] : (s = userAgent.match(/chrome\/([\d.]+)/)) ? browser.chrome = s[1] : (s = userAgent.match(/opera.([\d.]+)/)) ? browser.opera = s[1] : (s = userAgent.match(/version\/([\d.]+).*safari/)) ? browser.safari = s[1] : 0;
var version = "";
if (browser.ie) {
version = 'IE ' + browser.ie;
}
else {
if (browser.firefox) {
version = 'firefox ' + browser.firefox;
}
else {
if (browser.chrome) {
version = 'chrome ' + browser.chrome;
}
else {
if (browser.opera) {
version = 'opera ' + browser.opera;
}
else {
if (browser.safari) {
version = 'safari ' + browser.safari;
}
else {
version = '未知浏览器';
}
}
}
}
}
return version;
},
/**获得操作系统***/
ClientOs: function () {
var sUserAgent = navigator.userAgent;
var isWin = (navigator.platform == "Win32") || (navigator.platform == "Windows");
var isMac = (navigator.platform == "Mac68K") || (navigator.platform == "MacPPC") || (navigator.platform == "Macintosh") || (navigator.platform == "MacIntel");
if (isMac)
return "Mac";
var isUnix = (navigator.platform == "X11") && !isWin && !isMac;
if (isUnix)
return "Unix";
var isLinux = (String(navigator.platform).indexOf("Linux") > -1);
if (isLinux)
return "Linux";
if (isWin) {
var isWin2K = sUserAgent.indexOf("Windows NT 5.0") > -1 || sUserAgent.indexOf("Windows 2000") > -1;
if (isWin2K)
return "Win2000";
var isWinXP = sUserAgent.indexOf("Windows NT 5.1") > -1 || sUserAgent.indexOf("Windows XP") > -1;
if (isWinXP)
return "WinXP";
var isWin2003 = sUserAgent.indexOf("Windows NT 5.2") > -1 || sUserAgent.indexOf("Windows 2003") > -1;
if (isWin2003)
return "Win2003";
var isWinVista = sUserAgent.indexOf("Windows NT 6.0") > -1 || sUserAgent.indexOf("Windows Vista") > -1;
if (isWinVista)
return "WinVista";
var isWin7 = sUserAgent.indexOf("Windows NT 6.1") > -1 || sUserAgent.indexOf("Windows 7") > -1;
if (isWin7)
return "Win7";
}
return "other";
},
/****获得客户端ID****/
ClientID: function (name) {
var cookies = document.cookie.split(";");
var value = "";
for (var i = 0; i < cookies.length; i++) {
var temp = cookies[i].split("=");
var tempValue = temp[0].replace(/(^\s*)|(\s*$)/g, "");
if (tempValue == name) {
value = unescape(temp[1]);
break;
}
}
return value;
},
/****获得商品ID****/
SearchGid: function () {
var url = window.location.href;
var value = "";
if (url != undefined && url != "") {
url.replace(/-\d+-/, function (a, b, c) {
if (a != undefined && a != "" && a.length > 2) {
value = a.substring(1, a.length - 1);
}
});
}
return value;
},
/****获得站内搜索关键字****/
SearchKey: function () {
var url = window.location.href;
var value = "";
if (url != undefined && url != "") {
url.replace(/[=].*/, function (a, b, c) {
if (a != undefined && a != "" && a.length > 1) {
value = a.substring(1);
}
});
}
return value;
},
/**获得商品分类搜索编号**/
SearchCategory: function () {
var url = window.location.href;
var value = "";
if (url != undefined && url != "") {
url.replace(/-\d+/, function (a, b, c) {
if (a != undefined && a != "" && a.length > 1) {
value = a.substring(1);
}
});
}
return value;
},
/****站外搜索 Google 百度*****/
SearchSite: function (type) {
var referrer = document.referrer;
if (referrer != undefined && referrer != "") {
if ("google" == type) {
url.replace(new RegExp("(?:^|/?|&)q=([^&]*)(?:&|$)"), function (a, b, c) {
if (this._ch != undefined && a != undefined && a.length > 0) {
a = a.substring(a.indexOf("=") + 1, a.length - 1);
return a;
}
});
} else if ("baidu" == type) {
url.replace(new RegExp("(?:^|/?|&)wd=([^&]*)(?:&|$)"), function (a, b, c) {
if (this._ch != undefined && a != undefined && a.length > 0) {
a = a.substring(a.indexOf("=") + 1, a.length - 1);
return a;
}
});
} else if ("sogou" == type) {
url.replace(new RegExp("(?:^|/?|&)query=([^&]*)(?:&|$)"), function (a, b, c) {
if (this._ch != undefined && a != undefined && a.length > 0) {
a = a.substring(a.indexOf("=") + 1, a.length - 1);
return a;
}
});
} else if ("bing" == type) {
url.replace(new RegExp("(?:^|/?|&)q=([^&]*)(?:&|$)"), function (a, b, c) {
if (this._ch != undefined && a != undefined && a.length > 0) {
a = a.substring(a.indexOf("=") + 1, a.length - 1);
return a;
}
});
}
}
return "";
},
/******将值插入到数组中*********/
PushValue: function (key, value) {
if (this._ch != undefined) {
this._ch[key] = value;
}
},
/***自定义参数**/
Param: function (value) {
if (this._ch != undefined) {
this._ch["_ps"] = value;
}
},
/******提交数据到后台**********/
PostData: function () {
$.ajax({
url: "http://localhost:28482/Ajax/StatActions.aspx?t=" + Math.random(),
type: "post",
data: this._ch,
success: function (data) { }
});
},
/***初始化**/
Init: function () {
if (this._ch != undefined) {
this._ch = undefined;
}
this._ch = {};
if (this._Reg != undefined) {
this._Reg = undefined;
}
//初始化正则表达式 匹配URL this._Reg = new Array();
this._Reg[0] = "http://www.google.com.hk(.*)";
this._Reg[1] = "http://www.baidu.com(.*)";
this._Reg[2] = "http://www.sogou.com(.*)";
this._Reg[3] = "http://cn.bing.com(.*)"; //分析URL参数
var hostURL = window.location.href;
if (hostURL != undefined && hostURL != "") {
if ((new RegExp(this._Reg[4])).test(hostURL)) {
this._ch["_gid"] = this.SearchGid();
} else if ((new RegExp(this._Reg[7])).test(hostURL)) { } else if ((new RegExp(this._Reg[5])).test(hostURL)) {
this._ch["_cid"] = this.SearchCategory();
} else if ((new RegExp(this._Reg[6])).test(hostURL)) {
this._ch["_key"] = this.SearchKey();
}
this._ch["_tu"] = hostURL;
}
var referrer = document.referrer;
if (referrer != undefined && referrer != "") {
if ((new RegExp(this._Reg[0])).test(referrer)) {
this._ch["_key"] = this.SearchSite("google");
} else if ((new RegExp(this._Reg[1])).test(referrer)) {
this._ch["_key"] = this.SearchSite("baidu");
} else if ((new RegExp(this._Reg[2])).test(referrer)) {
this._ch["_key"] = this.SearchSite("sogou");
} else if ((new RegExp(this._Reg[3])).test(referrer)) {
this._ch["_key"] = this.SearchSite("bing");
}
this._ch["_su"] = referrer;
} //获取客户端相关信息
this._ch["_sw"] = this.ScreenWidth();
this._ch["_sh"] = this.ScreenHeight();
this._ch["_bw"] = this.Browse();
this._ch["_cs"] = this.ClientOs();
this._ch["_mid"] = this.ClientID("from_channelid");
this._ch["_ctid"] = this.ClientID("ClientKey"); },
_ch: undefined,
_Reg: undefined
userAgent 是 navigator 对象的一个只读属性,译为“用户代理”,简称“UA”。userAgent 会返回一个字符串,该字符串包含客户端使用的操作系统及版本、CPU 类型、浏览器及版本、浏览器渲染引擎、浏览器语言、浏览器插件等信息。
例如,chrome 浏览器在 Window7 平台下的 userAgent 示例:
Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.57 Safari/537.36
IE8 浏览器在 Window7 平台下的 userAgent 示例:
Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0)
下面是一个使用原生的javascript获取操作系统及其版本的demo:
//利用原生Js获取操作系统版本
function getOS() {
var sUserAgent = navigator.userAgent;
var isWin = (navigator.platform == "Win32") || (navigator.platform == "Windows");
var isMac = (navigator.platform == "Mac68K") || (navigator.platform == "MacPPC") || (navigator.platform == "Macintosh") || (navigator.platform == "MacIntel");
if (isMac) return "Mac";
var isUnix = (navigator.platform == "X11") && !isWin && !isMac;
if (isUnix) return "Unix";
var isLinux = (String(navigator.platform).indexOf("Linux") > -1);
if (isLinux) return "Linux";
if (isWin) {
var isWin2K = sUserAgent.indexOf("Windows NT 5.0") > -1 || sUserAgent.indexOf("Windows 2000") > -1;
if (isWin2K) return "Win2000";
var isWinXP = sUserAgent.indexOf("Windows NT 5.1") > -1 || sUserAgent.indexOf("Windows XP") > -1;
if (isWinXP) return "WinXP";
var isWin2003 = sUserAgent.indexOf("Windows NT 5.2") > -1 || sUserAgent.indexOf("Windows 2003") > -1;
if (isWin2003) return "Win2003";
var isWinVista= sUserAgent.indexOf("Windows NT 6.0") > -1 || sUserAgent.indexOf("Windows Vista") > -1;
if (isWinVista) return "WinVista";
var isWin7 = sUserAgent.indexOf("Windows NT 6.1") > -1 || sUserAgent.indexOf("Windows 7") > -1;
if (isWin7) return "Win7";
var isWin10 = sUserAgent.indexOf("Windows NT 10") > -1 || sUserAgent.indexOf("Windows 10") > -1;
if (isWin10) return "Win10";
}
return "other";
} document.write("您的操作系统是:"+getOS());
Javascript中获取浏览器类型和操作系统版本等客户端信息常用代码的更多相关文章
- JavaScript获取浏览器类型与版本
从网上找到一段使用JavaScript判断浏览器以及浏览器版本的比较好的代码,在此记录一下: <script type="text/javascript"> var S ...
- JavaScript学习总结(十八)——JavaScript获取浏览器类型与版本
从网上找到一段使用JavaScript判断浏览器以及浏览器版本的比较好的代码,在此记录一下: 1 <script type="text/javascript"> 2 v ...
- js获取浏览器类型和版本信息
bro () { let broName = 'Runing' let strStart = 0 let strStop = 0 let temp = '' let userAgent = windo ...
- JavaScript中两种类型的全局对象/函数【转】
Snandy Stop, thinking is the essence of progress. JavaScript中两种类型的全局对象/函数 这里所说的JavaScript指浏览器环境中的包括宿 ...
- JavaScript中判断对象类型方法大全1
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- javascript中获取非行间样式的方法
我们都知道一般在javascript中获取样式一般用的是nodeObj.style.attr这个属性的,但是这个属性只能获取行间样式非行间样式比如写在样式表中的样式那么用nodeObj.style.a ...
- JavaScript中判断对象类型的种种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- 转 JavaScript中判断对象类型的种种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- JS获取浏览器类型和版本号
JS获取浏览器类型和版本号,增加了IE11的判断. 2015/7/5更新: 简化代码逻辑 var zbrowser = {} var ua = navigator.userAgent.toLowerC ...
随机推荐
- redis配置文件详解及实现主从同步切换
原理:redis复制是怎么进行工作 如果设置了一个slave,不管是在第一次链接还是重新链接master的时候,slave会发送一个同步命令 然后master开始后台保存,收集所有对修改数据的命令.当 ...
- c++ --> 父类与子类间的继承关系
父类与子类间的继承关系 一.父类与子类 父类与子类的相互转换 1.派生类的对象可以赋给基类,反之不行 2.基类的指针可以指向派生类,反之不行 3.基类的引用可以初始化为派生类的对象,反之不行 4.派生 ...
- Algorithm --> Kruskal算法和Prim算法
最小生成树之Kruskal算法和Prim算法 Kruskal多用于稀疏图,prim多用于稠密图. 根据图的深度优先遍历和广度优先遍历,可以用最少的边连接所有的顶点,而且不会形成回路.这种连接所有顶点并 ...
- Jmeter 多用户同时登陆
在做性能测试的时候,很多情况需要多用户同时登录,下单,那怎么实现多用户的同时登录呢 可以通过CSV Data Set Config组件实现参数化登录 1.新建一个存放用户名和密码的文件, 和jmete ...
- linq分组求和_实体类和datatable
1.数据分组求合,分别用的实体类以及datatable来分组求合,还有分组求和之后的如何取值 //实体类版本 List<ProgramTimeModel> TotalAllList = G ...
- c语言程序设计第4周编程练习(素数和)
1 素数和(5分) 题目内容: 我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推. 现在,给定两个整数n和m,0<n<=m<=200,你的程序要计算第n个素数到第m个 ...
- Alpha冲刺No.10
一.站立式会议 我们的阿尔法冲刺也基本宣告血崩,虽然很多功能已经实现,但是并没有串联在一起,好在这周不需要上课,我们也能好好睡一觉 实现手机的定位系统 细化界面设计 解决数据库和软件交互的一些问题 二 ...
- GNU/Hurd笔记整理
patch 0 关于文件锁支持的解决方案,大部分是由Neal Walfield在2001年完成的.这些补丁由Marcus Brinkmann发表,随后被Michael Banck于2002年修改了部分 ...
- 201621123043《java程序设计》第五周学习总结
1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 接口. Comparable接口 .Comparator接口.compareTo. 1.2 尝试使用思维导图将这些关键词组织起来 ...
- OO前三次作业总结
一.第一次作业 1.程序设计分析 ![img](s1.ax1x.com/2018/04/02/CSgoSU.png) 图1 第一次作业类图 ![name](https://images2018.cnb ...