JS获得浏览器版本和操作系统版本的例子


Posted in Javascript onMay 13, 2014

于是,我们可以写出下面的代码:

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

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

今后,判断某种浏览器只需用if(Sys.ie)或if(Sys.firefox)等形式,而判断浏览器版本只需用if(Sys.ie == '8.0')或if(Sys.firefox == '3.0')等形式,表达起来还是非常优雅的。

获得操作系统版本:

<script type="text/javascript">
//用于获取系统版本(注意:本方法对Firefox、Chrome无效)
var ua = window.navigator.userAgent;
var osVersion = ua.split(";")[2];
var osV = osVersion.substr(osVersion.length-3,3); 
switch(osV)
{
 case "5.0":
  document.write("Windows2000");
  break;
 case "5.1":
  document.write("WindowsXP");
  break;
 case "5.2":
  document.write("Windows2003");
  break;
 case "6":
  document.write("Windows Vista");
  break;
 case "6.1":
  document.write("Windows 7");
  break;
 default:
 document.write("Others");
}
</script>
Javascript 相关文章推荐
JS删除数组元素的函数介绍
Mar 27 Javascript
JavaScript函数定义的常见注意事项小结
Sep 16 Javascript
JS实现网页游戏中滑块响应鼠标点击移动效果
Oct 19 Javascript
JS实现图片局部放大或缩小的方法
Aug 20 Javascript
HTML5 js实现拖拉上传文件功能
Nov 20 Javascript
js学习总结_轮播图之渐隐渐现版(实例讲解)
Jul 17 Javascript
js微信应用场景之微信音乐相册案例分享
Aug 11 Javascript
JS简单实现数组去重的方法分析
Oct 14 Javascript
基于jQuery Ajax实现下拉框无刷新联动
Dec 06 jQuery
在 Vue 项目中引入 tinymce 富文本编辑器的完整代码
May 04 Javascript
TypeScript 引用资源文件后提示找不到的异常处理技巧
Jul 15 Javascript
Vue中inheritAttrs的使用实例详解
Dec 31 Vue.js
当滚动条滚动到页面底部自动加载增加内容的js代码
May 13 #Javascript
js语法学习之判断一个对象是否为数组
May 13 #Javascript
js中定义一个变量并判断其是否为空的方法
May 13 #Javascript
jQuery 计算iframe 窗口大小的方法
May 13 #Javascript
js 调用百度地图api并在地图上进行打点添加标注
May 13 #Javascript
两种不同的方法实现js对checkbox进行全选和反选
May 13 #Javascript
js浏览器本地存储store.js介绍及应用
May 13 #Javascript
You might like
PHP安全编程之加密功能
2006/10/09 PHP
如何在PHP中使用Oracle数据库(3)
2006/10/09 PHP
轻松修复Discuz!数据库
2008/05/03 PHP
记录PHP错误日志 display_errors与log_errors的区别
2012/10/09 PHP
Zend的MVC机制使用分析(二)
2013/05/02 PHP
php自动加载机制的深入分析
2013/06/08 PHP
PHP 通过Socket收发十六进制数据的实现代码
2013/08/16 PHP
PHP使用flock实现文件加锁的方法
2015/07/01 PHP
PHP动态地创建属性和方法, 对象的复制, 对象的比较,加载指定的文件,自动加载类文件,命名空间
2016/05/06 PHP
PHP实现一个按钮点击上传多个图片操作示例
2020/01/23 PHP
JavaScript中出现乱码的处理心得
2009/12/24 Javascript
一个基于jquery的图片切换效果
2010/07/06 Javascript
jQuery随手笔记之常用的jQuery操作DOM事件
2015/11/29 Javascript
Angularjs实现上传图片预览功能
2017/09/01 Javascript
Vuex提升学习篇
2018/01/11 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
vue3.0自定义指令(drectives)知识点总结
2020/12/27 Vue.js
[54:41]2018DOTA2亚洲邀请赛3月30日 小组赛B组 VGJ.T VS paiN
2018/03/31 DOTA
详解Python中dict与set的使用
2015/08/10 Python
Python操作MongoDB数据库的方法示例
2018/01/04 Python
Tensorflow 实现将图像与标签数据转化为tfRecord文件
2020/02/17 Python
python编程进阶之异常处理用法实例分析
2020/02/21 Python
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
澳大利亚运动鞋零售商:The Athlete’s Foot
2018/11/04 全球购物
lululemon美国官网:瑜伽服+跑步装备
2018/11/16 全球购物
最新英语专业学生求职信范文
2013/09/21 职场文书
客户代表实习人员自我鉴定
2013/09/27 职场文书
新学期教师寄语
2014/04/02 职场文书
文明倡议书范文
2014/04/15 职场文书
学校端午节活动方案
2014/08/23 职场文书
反四风个人对照检查材料思想汇报
2014/09/25 职场文书
租车协议书
2015/01/27 职场文书
幼儿园教师自荐书
2015/03/06 职场文书
大学生求职自荐信
2015/03/24 职场文书
Win10 heic文件怎么打开 ? Win10 heic文件打开教程
2022/04/06 数码科技
Python 匹配文本并在其上一行追加文本
2022/05/11 Python