news 2026/2/18 0:01:35

jQuery UI 通过部件库(Widget Factory)扩展小部件

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery UI 通过部件库(Widget Factory)扩展小部件

jQuery UI 通过 Widget Factory 扩展小部件

Widget Factory$.widget)提供了强大的继承机制,让开发者可以轻松扩展现有 jQuery UI 小部件,或基于一个部件创建全新的变体。这正是 jQuery UI 官方许多小部件(如 Menu 是 Button 的扩展,Autocomplete 是 Menu 的扩展)实现方式的核心。

扩展基本语法
$.widget("custom.newWidgetName",$.existingNamespace.existingWidget,{// 新选项、方法、重写父类方法});
  • custom.newWidgetName:新部件的全名(命名空间 + 部件名)。
  • $.existingNamespace.existingWidget:要继承的父部件(例如$.ui.dialog)。
  • 第三个对象:定义新选项、重写父类方法、添加新方法。

关键方法:

  • this._super():调用父类同名方法。
  • this._superApply(arguments):带参数调用父类方法。
示例 1:简单扩展 Dialog(添加标题图标和自定义按钮)
$.widget("custom.iconDialog",$.ui.dialog,{// 新增默认选项options:{iconClass:"ui-icon-info",// 默认信息图标extraButton:null// 额外按钮配置 { text: "帮助", click: function }},// 重写 _create 方法,在标题栏添加图标_create:function(){// 先调用父类的 _createthis._super();// 在标题栏前添加图标if(this.options.iconClass){varicon=$("<span>").addClass("ui-dialog-title-icon "+this.options.iconClass).prependTo(this.uiDialogTitlebar);}// 添加额外按钮if(this.options.extraButton){varbuttons=this.options.buttons||{};buttons[this.options.extraButton.text]=this.options.extraButton.click;this.options.buttons=buttons;this._setOption("buttons",buttons);// 触发按钮更新}},// 可选:重写 open 方法,打开时添加动画效果open:function(){this._super();// 调用父类 openthis.element.effect("bounce",{times:3},300);// 额外弹跳效果}});

使用方式

<divid="myDialog"title="重要提示">这是一个带图标的对话框。</div><script>$(function(){$("#myDialog").customIconDialog({iconClass:"ui-icon-alert",modal:true,extraButton:{text:"帮助",click:function(){alert("帮助内容");}}});// 打开对话框$("#myDialog").customIconDialog("open");});</script>
示例 2:扩展 Tabs(添加“关闭”按钮到每个标签)
$.widget("custom.closableTabs",$.ui.tabs,{options:{closable:true},_create:function(){this._super();if(this.options.closable){this._addCloseButtons();}},// 在每个标签后添加关闭图标_addCloseButtons:function(){this.tablist.find("li").each(function(){var$tab=$(this);if(!$tab.find(".ui-tabs-close").length){$("<span>").addClass("ui-tabs-close ui-icon ui-icon-close").appendTo($tab).on("click",function(e){e.stopPropagation();varpanelId=$tab.find("a").attr("href");varindex=$("li",$tab.parent()).index($tab);$tab.closest(".ui-tabs").customClosableTabs("remove",index);});}});},// 重写 refresh 方法,确保新添加的标签也有关闭按钮refresh:function(){this._super();this._addCloseButtons();},// 可选:自定义 remove 方法,触发关闭事件remove:function(index){varpanelId=this.tabs.eq(index).attr("aria-controls");vareventData={panel:this.panels.eq(index)};if(this._trigger("beforeClose",null,eventData)===false){return;}this._super(index);this._trigger("close",null,eventData);}});

使用方式

<divid="tabs"><ul><li><ahref="#tab1">标签1</a></li><li><ahref="#tab2">标签2</a></li></ul><divid="tab1">内容1</div><divid="tab2">内容2</div></div><script>$("#tabs").customClosableTabs({closable:true,beforeClose:function(event,ui){returnconfirm("确定关闭此标签页?");}});</script>
示例 3:基于 Button 创建带加载状态的按钮
$.widget("custom.loadingButton",$.ui.button,{options:{loadingText:"加载中..."},// 添加 loading 方法loading:function(state){if(state){this.originalText=this.element.text();this.element.text(this.options.loadingText);this.options.disabled=true;this._super("option","disabled",true);}else{if(this.originalText){this.element.text(this.originalText);}this.options.disabled=false;this._super("option","disabled",false);}}});
总结优势
  • 代码复用:继承父部件的大部分功能,只修改需要的部分。
  • 保持兼容:新部件仍支持所有父部件的选项、方法、事件。
  • 一致性:自动继承 CSS 类、主题支持、状态管理等。
  • 链式继承:可以多层继承(如 A → B → C)。

通过 Widget Factory 的继承机制,你可以轻松创建功能更丰富、符合项目需求的自定义小部件,同时保持 jQuery UI 的统一风格和行为。

如果您有具体需求(如扩展 Datepicker 添加节假日高亮,或扩展 Autocomplete 支持异步加载),告诉我,我可以提供完整代码示例!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/16 4:54:49

AI助力Linux中文输入法开发:从零到一键部署

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 使用快马平台生成一个Linux中文输入法的基本框架&#xff0c;要求包含以下功能&#xff1a;1.基于Fcitx或IBus的输入法引擎适配层 2.支持拼音输入的核心算法模块 3.简繁体转换功能 …

作者头像 李华
网站建设 2026/2/10 3:05:20

31、Windows Phone应用设计与发布全流程指南

Windows Phone应用设计与发布全流程指南 一、Blend中的动画设计 在Blend的视角下,动画是随着时间逐步设置属性的过程。你可以定义一个时间点(例如1秒),然后改变该时间点的属性。这些属性变化可以使用故事板(Storyboard)映射到时间轴上,或者使用预定义的缓动函数自动塑…

作者头像 李华
网站建设 2026/2/16 18:37:15

32、Windows Phone应用开发与推广全解析

Windows Phone应用开发与推广全解析 1. 应用提交至Windows Phone应用商店 将应用推向市场的第一步是提交到Windows Phone应用商店。在提交应用页面,点击“审核并提交”按钮,即可将应用发送至商店。不过,提交审核的时间并不固定,应用获得批准可能需要长达5天的时间。如果应…

作者头像 李华
网站建设 2026/2/4 5:31:21

传统vsAI:Chrome插件开发效率对比实验

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请用最快的方式实现一个Chrome插件&#xff1a;1.监控指定网页内容变化&#xff1b;2.当检测到变化时显示桌面通知&#xff1b;3.支持设置监控间隔时间&#xff1b;4.提供简洁的配置…

作者头像 李华
网站建设 2026/2/2 8:54:18

CPI降温驱动的降息预期提振:黄金多头韧性下的AI量化解析

摘要&#xff1a;本文通过分析美11月CPI数据这一关键变量&#xff0c;结合市场情绪、技术面压力以及贵金属联动等多维度因素&#xff0c;运用AI模型对黄金等贵金属的价格波动及市场走势进行深度剖析。一、AI驱动的市场波动特征识别周四&#xff08;12月18日&#xff09;&#x…

作者头像 李华
网站建设 2026/2/16 9:44:34

gdocs2md:简单快速的Google文档转Markdown终极解决方案

gdocs2md&#xff1a;简单快速的Google文档转Markdown终极解决方案 【免费下载链接】gdocs2md Convert a Google Drive Document to the Markdown format, suitable for publishing. 项目地址: https://gitcode.com/gh_mirrors/gd/gdocs2md gdocs2md 是一个功能强大且易…

作者头像 李华