gpt4 book ai didi

javascript - 如何扩展现有的 jQuery UI 小部件?

转载 作者:可可西里 更新时间:2023-11-01 01:45:48 26 4
gpt4 key购买 nike

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


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

最佳答案

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

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

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

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

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

扩展一个小部件:

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

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

在继承或扩展一个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 );
},
});

关于javascript - 如何扩展现有的 jQuery UI 小部件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13711127/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com