21

我们最近将 jQuery 升级到 1.9.0,但它破坏了我们的醉酒插件。它的live功能现在会导致错误。

$('.tooltip, abbr').tipsy({
    live: true
});

TypeError: this[binder] is not a function

是否有任何修复或补丁?谷歌搜索并没有带来任何有用的东西。


更新:

感谢您的回答。我决定尝试自己解决这个问题,因为我找不到任何补丁。

经检查,错误似乎很容易追踪。Tipsy 插件可以很容易地被修补以使用该on功能而不是已弃用的live功能。在tipsy插件中,我替换了以下代码:

if (options.trigger != 'manual') {
    var binder = options.live ? 'live' : 'bind',
        eventIn = options.trigger == 'hover' ? 'mouseenter' : 'focus',
        eventOut = options.trigger == 'hover' ? 'mouseleave' : 'blur';
    this[binder](eventIn, enter)[binder](eventOut, leave);
}

和:

if (options.trigger != 'manual') {
    var eventIn = options.trigger == 'hover' ? 'mouseenter' : 'focus',
        eventOut = options.trigger == 'hover' ? 'mouseleave' : 'blur';
    if (options.live)
        $(document).on(eventIn, this.selector, enter).on(eventOut, this.selector, leave);
    else
        this.bind(eventIn, enter).bind(eventOut, leave);
}

奇迹般有效。:)

4

2 回答 2

14

您需要包含 jquery 迁移插件,因为您正在使用live:true它利用jquery.live在 jquery 1.9 中删除

为了向后兼容,他们创建了一个迁移插件,可以在此处下载并包含迁移插件以添加对已删除方法和实用程序的支持。

我会做类似的事情

if (options.trigger != 'manual') {
    var eventIn  = options.trigger == 'hover' ? 'mouseenter' : 'focus',
        eventOut = options.trigger == 'hover' ? 'mouseleave' : 'blur';
    if(options.live){
      $(this.context).on(eventIn, this.selector, enter).on(eventOut, this.selector, leave);
    } else {
      this.on(eventIn, enter).on(eventOut, leave);
    }
}
于 2013-03-18T09:48:41.343 回答
0

问题是这个插件仍然.live()用来让live你在那里使用的方法工作,它已被弃用并已被替换为.on().

您应该尝试搜索插件的更新版本或尝试自行替换它。

于 2013-03-18T09:53:09.003 回答