前端开发过程中浏览器版本的两种判定方法


Posted in Javascript onOctober 30, 2013

在网上查找浏览器及版本判定方法有好多,此处小弟总结一二,以节省大家时间。

1.jquery的方法:

通过正则表达式可判定常用浏览器及其版本。

<span style="font-size:12px">function allinfo(){ var ua = navigator.userAgent; 
ua = ua.toLowerCase(); 
var match = /(webkit)[ \/]([\w.]+)/.exec(ua) || 
/(opera)(?:.*version)?[ \/]([\w.]+)/.exec(ua) || 
/(msie) ([\w.]+)/.exec(ua) || 
!/compatible/.test(ua) && /(mozilla)(?:.*? rv:([\w.]+))?/.exec(ua) || []; 
//如果需要获取浏览器版本号:match[2] 
switch(match[1]){ 
case "msie": //ie 
if (parseInt(match[2]) === 6){ //ie6 
alert("ie6"); 
alert("暂时不支持IE7.0及以下版本浏览器,请升级您的浏览器版本!"); 
//document.getElementById("hid").style.display = "none"; 
// document.getElementById("show").style.display = "block"; 
//document.getElementById("nosee_b").style.display = "none"; 
} 
else if (parseInt(match[2]) === 7) { //ie7 
alert("ie7"); 
//document.getElementById("hid").style.display = "none"; 
// document.getElementById("show").style.display = "block"; 
} 
else if (parseInt(match[2]) === 8){ //ie8 
alert("ie8"); 
} 
else if(parseInt(match[2]) === 9){ 
alert("ie9"); 
//document.getElementById("hid").style.display = "none"; 
} 
break; 
case "webkit": //safari or chrome 
//alert("safari or chrome"); 
// document.getElementById("middle").style.display = "none"; 
break; 
case "opera": //opera 
alert("opera"); 
break; 
case "mozilla": //Firefox 
alert("Firefox"); 
//document.getElementById("hid").style.display = "none"; 
break; 
default: 
break; 
} 
} </span>

此处用到“===”,了解到其与“==”和“=”的关系

=这个就不多说了,开发中是给参数赋值。

== equality 等同,=== identity 恒等。
==, 两边值类型不同的时候,要先进行类型转换,再比较。
===,不做类型转换,类型不同的一定不等。

For Example:
如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较:
a、如果一个是null、一个是undefined,那么[相等]。
b、如果一个是字符串,一个是数值,把字符串转换成数值再进行比较。
c、如果任一值是 true,把它转换成 1 再比较;如果任一值是 false,把它转换成 0 再比较。
d、如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。js核心内置类,会尝试valueOf先于toString;例外的是Date,Date利用的是toString转换。

2.HTML中的注释方法

(1)HTML中的注释方法
可使用如下代码检测当前IE浏览器的版本(注意:在非IE浏览器中是看不到效果的),此方法用于IE5及以上版本。
HTML 的注释格式是 <!-- Comment content --> , IE 对HTML注释做了一些扩展,使之可以支持条件判断表达式:
<!--[if expression]> HTML <![endif]--> 当表达式expression 为True 的时候,显示 HTML 内容。
[if IE] 判断是否IE
[if !IE] 判断是否不是IE
[if lt IE 5.5] 判断是否是IE5.5 以下版本。 (<)
[if lte IE 6] 判断是否等于IE6 版本或者以下 (<=)
[if gt IE 5] 判断是否IE5以上版本 (> )
[if gte IE 7] 判断是否 IE7 版本或者以上
[if !(IE 7)] 判断是否不是IE7
[if (gt IE 5)&(lt IE 7)] 判断是否大于IE5, 小于IE7
[if (IE 6)|(IE 7)] 判断是否IE6 或者 IE7

lte:就是Less than or equal to的简写,也就是小于或等于的意思。 lt :就是Less than的简写,也就是小于的意思。 gte:就是Greater than or equal to的简写,也就是大于或等于的意思。 gt :就是Greater than的简写,也就是大于的意思。 ! : 就是不等于的意思,跟javascript里的不等于判断符相同
例子:

<!--[if IE]><p>You are using Internet Explorer.</p><![endif]--> 
<!--[if IE 7]><p>Welcome to Internet Explorer 7!</p><![endif]--> 
<!--[if !(IE 7)]><p>You are not using version 7.</p><![endif]--> 
<!--[if gte IE 7]><p>You are using IE 7 or greater.</p><![endif]--> 
<!--[if (IE 5)]><p>You are using IE 5 (any version).</p><![endif]--> 
<!--[if (gte IE 5.5)&(lt IE 7)]><p>You are using IE 5.5 or IE 6.</p><![endif]--> 
<!--[if lt IE 5.5]><p>Please upgrade your version of Internet Explorer.</p><![endif]-->

(2)应该如何应用条件注释

因为IE各版本的浏览器对我们制作的WEB标准的页面解释不一样,具体就是对CSS的解释不同,我们为了兼容这些,可运用条件注释来各自定义,最终达到兼容的目的。

比如: < !?- 默认先调用css.css样式表 ?->

<link rel="stylesheet" type="text/css" href="css.css" />< !-?[if IE 7]>

<!?- 如果IE浏览器版是7,调用ie7.css样式表- ?>

<link rel="stylesheet" type="text/css" href="ie7.css" />< ![endif]?->

<!?-[if lte IE 6]>

<!?- 如果IE浏览器版本小于等于6,调用ie.css样式表 -?>

<link rel="stylesheet" type="text/css" href="ie.css" />< ![endif]?> 这其中就区分了IE7和IE6向下的浏览器对CSS的执行,达到兼容的目的。同时,首行默认的css.css还能与其他非IE浏览器实现兼容。

注意:默认的CSS样式应该位于HTML文档的首行,进行条件注释判断的所有内容必须位于该默认样式之后。 比如如下代码,在IE浏览器下执行显示为红色,而在非IE浏览器下显示为黑色。如果把条件注释判断放在首行,则不能实现。该例题很能说明网页对IE浏览器和非IE浏览器间的兼容性问题解决。 <style type="text/css"> body{ background-color: #000; } < /style> < !-?[if IE]>

<style type="text/css">body{background-color: #F00;}< /style>< ![endif]?->

同时,有人会试图使用<!?-[if !IE]>来定义非IE浏览器下的状况,但注意:条件注释只有在IE浏览器下才能执行,这个代码在非IE浏览下非单不是执行该条件下的定义,而是当做注释视而不见。

正常就是默认的样式,对IE浏览器需要特殊处理的,才进行条件注释。在HTML文件里,而不能在CSS文件中使用。

现在的DWcs4里面,已经装备了这些注释:在“窗口-->代码片段-->注释”里。其他的版本没太注意到。

此文参考:判断浏览器版本的语句,用于个浏览器兼容,js判断运行jsp页面的浏览器类型以及版本

Javascript 相关文章推荐
用js计算页面执行时间的函数
Dec 07 Javascript
jQuery中绑定事件的命名空间详解
Apr 05 Javascript
解决火狐浏览器下JS setTimeout函数不兼容失效不执行的方法
Nov 14 Javascript
jQuery动态修改超链接地址的方法
Feb 13 Javascript
vuejs2.0实现分页组件使用$emit进行事件监听数据传递的方法
Feb 22 Javascript
微信小程序实现实时圆形进度条的方法示例
Feb 24 Javascript
vue-cli中打包图片路径错误的解决方法
Oct 26 Javascript
Vue2.0 axios前后端登陆拦截器(实例讲解)
Oct 27 Javascript
JS使用cookie保存用户登录信息操作示例
May 30 Javascript
Vue 使用计时器实现跑马灯效果的实例代码
Jul 11 Javascript
Element-ui DatePicker显示周数的方法示例
Jul 19 Javascript
Vue之封装公用变量以及实现方式
Jul 31 Javascript
js判断运行jsp页面的浏览器类型以及版本示例
Oct 30 #Javascript
JS复制到剪贴板示例代码
Oct 30 #Javascript
3种不同方式的焦点图轮播特效分享
Oct 30 #Javascript
js同比例缩放图片的小例子
Oct 30 #Javascript
javascript实现颜色渐变的方法
Oct 30 #Javascript
window.onload和$(function(){})的区别介绍
Oct 30 #Javascript
js history对象简单实现返回和前进
Oct 30 #Javascript
You might like
PHP函数utf8转gb2312编码
2006/12/21 PHP
php echo()和print()、require()和include()函数区别说明
2010/03/27 PHP
解析php中static,const与define的使用区别
2013/06/18 PHP
[原创]php逐行读取txt文件写入数组的方法
2015/07/02 PHP
简单解析PHP程序的运行流程
2016/06/23 PHP
IE JS编程需注意的内存释放问题
2009/06/23 Javascript
javascript 函数使用说明
2010/04/07 Javascript
让新消息在网页标题闪烁提示的jQuery代码
2013/11/04 Javascript
JS控件ASP.NET的treeview控件全选或者取消(示例代码)
2013/12/16 Javascript
js控制table合并具体实现
2014/02/20 Javascript
JQuery中使用ajax传输超大数据的解决方法
2014/07/14 Javascript
Node.js抓取中文网页乱码问题和解决方法
2015/02/10 Javascript
JavaScript获取表格(table)当前行的值、删除行、增加行
2015/07/03 Javascript
实例讲解js验证表单项是否为空的方法
2016/01/09 Javascript
JS实现title标题栏文字不间断滚动显示效果
2016/09/07 Javascript
关于vue.js弹窗组件的知识点总结
2016/09/11 Javascript
Bootstrap表单控件使用方法详解
2017/01/11 Javascript
判断div滑动到底部的scroll实例代码
2017/11/15 Javascript
AngularJS实现的2048小游戏功能【附源码下载】
2018/01/03 Javascript
尝试自己动手用react来写一个分页组件(小结)
2018/02/09 Javascript
jQuery实现上下滚动公告栏详细代码
2018/11/21 jQuery
Vue CLI3基础学习之pages构建多页应用
2019/06/02 Javascript
浅谈layer的Icon样式以及一些常用的layer窗口使用方法
2019/09/11 Javascript
在vue中利用v-html按分号将文本换行的例子
2019/11/14 Javascript
使用Vue实现一个树组件的示例
2020/11/06 Javascript
[04:01]2014DOTA2国际邀请赛 TITAN告别Ohaiyo期望明年再战
2014/07/15 DOTA
Django框架实现的普通登录案例【使用POST方法】
2019/05/15 Python
pandas 如何分割字符的实现方法
2019/07/29 Python
下载官网python并安装的步骤详解
2019/10/12 Python
导出HTML5 Canvas图片并上传服务器功能
2019/08/16 HTML / CSS
严选全球尖货,立足香港:Bonpont宝盆
2018/07/24 全球购物
预备党员学习十八届三中全会精神思想汇报
2014/09/13 职场文书
公司团队口号霸气押韵
2015/12/24 职场文书
护理心得体会范文
2016/01/22 职场文书
JavaScript+HTML实现学生信息管理系统
2021/04/20 Javascript
MySQL数字类型自增的坑
2021/05/07 MySQL