现在的位置: 首页 > 综合 > 正文

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

2013年10月13日 ⁄ 综合 ⁄ 共 764字 ⁄ 字号 评论关闭

    在解决 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) || 即可

 

 

抱歉!评论已关闭.