【问题标题】:How to extend an existing jQuery UI widget?如何扩展现有的 jQuery UI 小部件?
【发布时间】:2012-12-04 20:15:05
【问题描述】:

我正在使用 jQuery v1.8.3 和 jQuery UI v1.9.2。我想扩展现有的 jQuery UI 小部件(在我的例子中是 Autocomplete 小部件),方法是添加和覆盖一些选项和方法,但保留其他功能与官方版本中的功能相同。我怎样才能使它成为“正确”(也许是“标准”)的方式?


PS:我在网络上搜索(12、...),发现文档大多与 创建新的 jQuery UI 小部件相关但不能扩展现有的。

【问题讨论】:

  • 定义“扩展”。根据您想要做什么,您通常只需添加新方法,然后覆盖一些现有方法以使用您添加的功能。如autocomplete accentFolding extension。没有太多干净且面向未来的方法。
  • 我认为任何人都可以提供的唯一答案是您必须谨慎行事。您必须熟悉代码库,然后确保维护彼此之间的合约功能。
  • @Fabrício Matté - “没有太多干净且面向未来的方式”是什么意思?
  • @thatidiotguy - 简单地说,我只想添加新的方法和选项,但我不打算覆盖现有的方法。
  • 好吧,毕竟您是在编辑插件功能。您无法预见在未来版本中会发生什么变化。您可以在覆盖之前创建对原始方法的引用,用您自己的代码覆盖它,并在添加代码之前/之后调用原始方法,这是最接近干净/面向未来的方式,但不是 100%。

标签: javascript jquery jquery-ui plugins extending


【解决方案1】:

在 jQuery UI 1.9+ 中,扩展小部件的方式与创建新小部件的方式相同。小部件工厂 ($.widget()) 支持几种场景:

使用基本小部件 ($.Widget) 作为起点创建一个新小部件:

$.widget( "ns.widget", { ... } )

创建一个继承自现有小部件的新小部件:

$.widget( "ns.widget", $.ns.existingWidget, { ... } )

扩展小部件:

$.widget( "ns.widget", $.ns.widget, { ... } )

您会注意到扩展语法和继承语法是相同的。小部件工厂足够聪明,可以注意到您正在创建的小部件和您从其继承的小部件是相同的并适当地处理它。

在继承或扩展小部件时,您只需要定义要更改或添加的内容。基本小部件上还存在一些新方法,可以更轻松地使用继承和更改上下文的方法。阅读jQuery.Widget documentation 以获取方法及其描述的完整列表。如果您正在扩展小部件,您肯定会想了解_super()

这是一个示例,它将默认 delay 选项更改为 500 并添加一个新选项 prefix,该选项将添加到所有建议中:

$.widget( "ui.autocomplete", $.ui.autocomplete, {
    options: {
        delay: 500,
        prefix: ""
    },

    _renderItem: function( ul, item ) {
        var label = item.label;
        if ( this.options.prefix ) {
            label = this.options.prefix + " " + label;
        }
        return $( "<li>" )
            .append( $( "<a>" ).text( label ) )
            .appendTo( ul );
    },
});

【讨论】:

  • 扩展继承有什么区别?
  • 继承创建一个新的小部件,而不改变现有的小部件。扩展小部件会更改现有小部件的行为,而不是创建新小部件。
  • 如果它节省了任何人我刚刚经历的相同时间/头痛,请注意您不能扩展 jQuery UI 的日期选择器(在 1.10 版或更高版本中),因为它不是基于小部件早期版本的工厂。请参阅此问题stackoverflow.com/questions/25011698/…。对于其他小部件,扩展应该可以正常工作。
猜你喜欢
  • 2011-02-01
  • 1970-01-01
  • 2012-03-07
  • 1970-01-01
  • 2012-12-09
  • 2019-02-12
  • 1970-01-01
  • 2020-05-24
  • 1970-01-01
相关资源
最近更新 更多