jQuery下通过$.browser来判断浏览器
2015-06-05 12:35
645 查看
用jQuery来判断浏览器的类型,主要是使用$.browser这个工具类
使用方法:
$.browser.['浏览器关键字']
jQuery 使用的是通过正则来匹配userAgent判断浏览器的种类和版本.
如果我们要来判断当前浏览器是否是IE6应该如何来判断?
$.browser.msie&&($.browser.version == "6.0")&&!$.support.style
同样jQuery判断浏览器是否为IE7
$.browser.msie&&($.browser.version == "7.0")
如果不考虑向后兼容性,又不想为了判断各浏览器类型而导入jQuery
判断IE最简单的方法是
$.browser是通过正则表达式来匹配userAgent来判断浏览器版本和种类的.jquery1.3.2版本的文档中已经声明jquery.browser及jquery.browser.version建议弃用,可以使用jquery.support来代替
$.browser在jQuery1.9里被删除了,所以项目的js代码里用到$.browser的地方就会报这个错。
jQuery1.9里对不少API做了废弃或者删除。幸运的是,jQuery社区考虑到了这么做给开发人员带来的麻烦,在1.9同时也推出了一个新插件jQuery Migration,该插件可以检查出在1.9之后被废弃或者删除的API,恢复原有功能,从而保证已有的js代码能在最新的jQuery下正常运行。
下面是具体的解决方法,只需要在jQuery引用后加上一行对jQuery Migration的引用即可。
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.1.1.js"></script>
但是目前的情况来看,jquery.support并不好用,而且是非常的难用,我们还是老老实实的用$.browser来判断浏览器类型吧
如果是为了判断IE的版本我还是推荐用IE的条件表达式来书写JS
使用方法:
$.browser.['浏览器关键字']
$(function() { if($.browser.msie) { alert("this is msie"); } else if($.browser.safari) { alert("this is safari!"); } else if($.browser.mozilla) { alert("this is mozilla!"); } else if($.browser.opera) { alert("this is opera"); } else { alert("i don't konw!"); }我们看下jQuery的源码:
var userAgent = navigator.userAgent.toLowerCase(); // Figure out what browser is being used jQuery.browser = { version: (userAgent.match( /.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [])[1], safari: /webkit/.test( userAgent ), opera: /opera/.test( userAgent ), msie: /msie/.test( userAgent ) && !/opera/.test( userAgent ), mozilla: /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent ) };
jQuery 使用的是通过正则来匹配userAgent判断浏览器的种类和版本.
如果我们要来判断当前浏览器是否是IE6应该如何来判断?
$.browser.msie&&($.browser.version == "6.0")&&!$.support.style
同样jQuery判断浏览器是否为IE7
$.browser.msie&&($.browser.version == "7.0")
如果不考虑向后兼容性,又不想为了判断各浏览器类型而导入jQuery
判断IE最简单的方法是
if(document.all){ alert("IE6") }
$.browser是通过正则表达式来匹配userAgent来判断浏览器版本和种类的.jquery1.3.2版本的文档中已经声明jquery.browser及jquery.browser.version建议弃用,可以使用jquery.support来代替
$.browser在jQuery1.9里被删除了,所以项目的js代码里用到$.browser的地方就会报这个错。
jQuery1.9里对不少API做了废弃或者删除。幸运的是,jQuery社区考虑到了这么做给开发人员带来的麻烦,在1.9同时也推出了一个新插件jQuery Migration,该插件可以检查出在1.9之后被废弃或者删除的API,恢复原有功能,从而保证已有的js代码能在最新的jQuery下正常运行。
下面是具体的解决方法,只需要在jQuery引用后加上一行对jQuery Migration的引用即可。
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.1.1.js"></script>
但是目前的情况来看,jquery.support并不好用,而且是非常的难用,我们还是老老实实的用$.browser来判断浏览器类型吧
如果是为了判断IE的版本我还是推荐用IE的条件表达式来书写JS
<!--[if IE]> <script type="text/javascript"> alert("ie") </script> <![endif]--> <!--[if IE 6]> <script type="text/javascript"> alert("ie6") </script> <![endif]--> <!--[if IE 7]> <script type="text/javascript"> alert("ie7") </script> <![endif]-->
相关文章推荐
- jquery插件NProgress.js制作网页加载进度条
- jQuery 事件
- [jQuery] 选择器和事件
- jQuery插件EnPlaceholder实现输入框提示文字
- html文件中jquery与velocity变量中的$冲突的解决方法
- jQuery 选择器
- jQuery验证控件jquery.validate.js使用说明+中文API
- jQuery入门
- jQuery 语法(一)
- [jQuery] 初识jQuery
- 基于jQuery+JSON的省市二三级联动效果
- jQuery的三种$()
- 判断一个对象是否为jquery对象的方法
- jQuery实现图片延迟加载
- 简单的(jquery)DIV点选框
- ie下,jquery为动态添加的节点添加事件,用live
- jquery的smartWizard插件使用方法
- jQuery+HTML5实现手机摇一摇换衣特效
- Jquery(进阶一) 日期控件My97DatePicker的基本用法
- jquery判断ie与使用ie来判断ie,推荐ie样式块