jQuery.browser脚本或shim用于向后兼容1.9.1的插件

时间:2013-03-21 06:26:47

标签: jquery internet-explorer quicksand

我正在尝试使用quicksand jquery插件,我在jquery 1.9.1中遇到此错误。

  

“未捕获的TypeError:无法读取未定义的属性'msie'”

我知道msie是jQuery.browser属性的标志jQuery.browser自1.3版以来已被弃用,并在jQuery 1.9.0中被删除

这就是导致错误的原因。但是有没有一个解决办法让流沙再次起作用?

任何帮助或建议都会很棒!

提前致谢!

2 个答案:

答案 0 :(得分:4)

Intrepid Developer的注意事项

jQuery.browserjQuery.support上的(少数)强制性词语:

  

jQuery.browser 包含useragent的标记,从navigator.userAgent读取。 我们建议不要使用此属性;请尝试使用功能检测(请参阅 jQuery.support )。 jQuery.browser可能会在未来的jQuery版本中移动到插件中。

     

不是使用$.browser来检测当前用户代理并根据运行的浏览器更改页面显示,而是使用特征检测的良好做法。为了简化这个过程,jQuery执行了许多这样的测试并设置了jQuery.support对象的属性。

故事的道德:更新您的项目,消除对jQuery.browser的依赖,并在必要时使用特征检测。要测试和查找项目过度依赖已弃用或已删除的方法或属性的区域,请参阅jQuery-migrate

另请参阅Modernizr.jsYepNope.js以了解jquery特征检测的替代方法。


用于替换$.browser的jQuery shim文件,由fancyBox-rails项目提供:

// jQuery 1.9 has removed the `$.browser` property, fancybox relies on
// it, so we patch it here if it's missing.
// This has been copied from jQuery migrate 1.1.1.
if ( !jQuery.browser ) {
  var uaMatch = function( ua ) {
    ua = ua.toLowerCase();

    var match = /(chrome)[ \/]([\w.]+)/.exec( ua ) ||
      /(webkit)[ \/]([\w.]+)/.exec( ua ) ||
      /(opera)(?:.*version|)[ \/]([\w.]+)/.exec( ua ) ||
      /(msie) ([\w.]+)/.exec( ua ) ||
      ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec( ua ) ||
      [];

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

  matched = uaMatch( navigator.userAgent );
  browser = {};

  if ( matched.browser ) {
    browser[ matched.browser ] = true;
    browser.version = matched.version;
  }

  // Chrome is Webkit, but Webkit is also Safari.
  if ( browser.chrome ) {
    browser.webkit = true;
  } else if ( browser.webkit ) {
    browser.safari = true;
  }

  jQuery.browser = browser;
}

https://github.com/hecticjeff/fancybox-rails/blob/master/vendor/assets/javascripts/jquery.browser.js

答案 1 :(得分:0)

您使用的quicksand插件包含从版本code开始的(i.e $.browser)中删除的jQuery 1.9