您的位置:首页 > Web前端 > JQuery

关于jQuery库判断chrome浏览器有问题的解决办法

2010-11-09 15:54 295 查看
在解决 www.udrop.net 中关于anchor navigation (也可以说是保存AJAX提交时历史状态的保留即可使浏览器后退前进按钮生效)中碰到一些问题。在jquery.history.js使用时,发现它在判断chrome的时候把chrome认成了是safari(原因应该是jquery先判断浏览器的user-agent里包含webkit<chrome也是用webkit引擎>,如果包含webkit就直接判断为safari).这也直接导致jquery.history.js中执行绑定的回调函数时出错。

可以在jquery.js(我的是1.4.2版)中稍微修改一下判断浏览器的代码。下面是jquery源代码的写法:



uaMatch:function(a)

{

a=a.toLowerCase();

a=/(webkit)[ //]([/w.]+)/.exec(a) || /(opera)(?:.*version)?[ //]([/w.]+)/.exec(a) ||

/(msie) ([/w.]+)/.exec(a) || !/compatible/.test(a)&&/(mozilla)(?:.*? rv:([/w.]+))?/.exec(a) ||

[];

return {browser:a[1] || "",version:a[2]||"0"}

},

browser:{}

});

P=c.uaMatch(P);

if(P.browser) {

c.browser[P.browser]=true;

c.browser.version=P.version

}

if(c.browser.webkit)c.browser.safari=true;

在判断浏览器的各个正则表达式中最前面加入一个

/(chrome)[ //]([/w.]+)/.exec(a) || 即可
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐