【转】jquery判断浏览器类型、js判断浏览器版本

$.browser.['浏览器关键字']

01$(function() {
02if($.browser.msie) {
03alert("this is msie");
04}
05else if($.browser.safari)
06{
07alert("this is safari!");
08}
09else if($.browser.mozilla)
10{
11alert("this is mozilla!");
12}
13else if($.browser.opera) {
14alert("this is opera");
15}
16else {
17alert("i don't konw!");
18}

我们看下jQuery的源码:

1var userAgent = navigator.userAgent.toLowerCase();
2// Figure out what browser is being used
3jQuery.browser = {
4version: (userAgent.match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [])[1],
5safari: /webkit/.test( userAgent ),
6opera: /opera/.test( userAgent ),
7msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ),
8mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent )
9};

jQuery 使用的是通过正则来匹配userAgent判断浏览器的种类和版本.

如果我们要来判断当前浏览器是否是IE6应该如何来判断?

1$.browser.msie&&($.browser.version == "6.0")&&!$.support.style

同样jQuery判断浏览器是否为IE7

1$.browser.msie&&($.browser.version == "7.0")

如果不考虑向后兼容性,又不想为了判断各浏览器类型而导入jQuery

判断IE最简单的方法是

1if(document.all){
2alert("IE6")
3}

$.browser是通过正则表达式来匹配userAgent来判断浏览器版本和种类的.jquery1.3.2版本的文档中已经声明jquery.browser及jquery.browser.version建议弃用,可以使用jquery.support来代替

但是目前的情况来看,jquery.support并不好用,而且是非常的难用,我们还是老老实实的用$.browser来判断浏览器类型吧

如果是为了判断IE的版本我还是推荐用IE的条件表达式来书写JS

01<!--[if IE]>
02<script type="text/javascript">
03alert("ie")
04</script>
05<![endif]-->
06<!--[if IE 6]>
07<script type="text/javascript">
08alert("ie6")
09</script>
10<![endif]-->
11<!--[if IE 7]>
12<script type="text/javascript">
13alert("ie7")
14</script>
15<![endif]-->
16这个比我们手动通过$.browser来判断IE版本更精准,也不用去记jquery的browser的使用方法了

转载于:https://www.cnblogs.com/shengchanlix/archive/2011/05/14/2046523.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值