news 2026/5/23 2:28:19

jQuery UI 如何使用部件库(Widget Factory)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery UI 如何使用部件库(Widget Factory)

jQuery UI 如何使用部件库(Widget Factory)

jQuery UI 的所有小部件(Datepicker、Tabs、Dialog 等)都基于Widget Factory$.widget)构建。作为开发者,你可以直接使用 Widget Factory 来:

  1. 创建全新的自定义小部件
  2. 扩展现有的 jQuery UI 小部件(最常见的使用方式)。
  3. 利用其统一的 API 和生命周期来管理复杂交互。

下面一步步说明如何在项目中使用 Widget Factory。

1. 前提:引入 jQuery UI

Widget Factory 是 jQuery UI 的一部分,必须引入 jQuery UI 的 JS 文件(它会自动在jQuery.ui命名空间下暴露$.widget)。

<scriptsrc="https://code.jquery.com/jquery-3.7.1.min.js"></script><scriptsrc="https://code.jquery.com/ui/1.14.1/jquery-ui.min.js"></script>
2. 创建一个全新自定义小部件

使用$.widget()定义一个独立的新部件。

// 定义一个简单的计数器小部件$.widget("custom.counter",{// 默认选项options:{value:0,step:1},// 创建时调用(初始化 DOM 和事件)_create:function(){this.element.addClass("custom-counter ui-widget ui-corner-all");this.display=$("<span>").addClass("counter-display").text(this.options.value).appendTo(this.element);this.incrementBtn=$("<button>").text("+").addClass("ui-button ui-state-default").on("click",()=>this._increment()).appendTo(this.element);this.decrementBtn=$("<button>").text("-").addClass("ui-button ui-state-default").on("click",()=>this._decrement()).appendTo(this.element);},// 自定义方法:增加计数_increment:function(){this.value(this.options.value+this.options.step);},// 自定义方法:减少计数_decrement:function(){this.value(this.options.value-this.options.step);},// 公共方法:获取或设置值value:function(newValue){if(newValue===undefined){returnthis.options.value;}this._setOption("value",newValue);},// 选项改变时自动调用_setOption:function(key,value){this._super(key,value);// 调用父类if(key==="value"){this.display.text(value);this._trigger("change",null,{value:value});// 触发 change 事件}},// 销毁时清理_destroy:function(){this.element.removeClass("custom-counter ui-widget ui-corner-all").empty();this._super();}});

使用自定义小部件

<divid="myCounter"></div><script>$(function(){$("#myCounter").customCounter({value:10,step:5});// 绑定事件$("#myCounter").on("customcounterchange",function(event,ui){console.log("当前值:",ui.value);});// 调用方法$("#myCounter").customCounter("value",50);});</script>
3. 扩展现有 jQuery UI 小部件(最实用的方式)

继承官方小部件,只添加或修改需要的功能。

// 扩展 Dialog,添加默认的“帮助”按钮和标题图标$.widget("custom.helpDialog",$.ui.dialog,{options:{helpText:"点击这里获取帮助",iconClass:"ui-icon-help"},_create:function(){this._super();// 先调用父类的 _create// 添加标题图标if(this.options.iconClass){$("<span>").addClass(this.options.iconClass+" ui-dialog-title-icon").prependTo(this.uiDialogTitlebar.find(".ui-dialog-title"));}// 添加帮助按钮varbuttons=this.options.buttons||{};buttons["帮助"]=()=>alert(this.options.helpText);this.option("buttons",buttons);}});

使用扩展后的 Dialog

<divid="helpDlg"title="使用说明">这是一个带帮助按钮的对话框。</div><script>$("#helpDlg").customHelpDialog({modal:true,helpText:"本功能用于演示 Widget Factory 扩展",iconClass:"ui-icon-info"});$("#helpDlg").customHelpDialog("open");</script>
4. 常见 Widget Factory 使用技巧
  • 调用父类方法:始终在重写的方法中先调用this._super()this._superApply(arguments)
  • 触发事件this._trigger("eventName", event, uiData),用户可通过.on("widgetNameeventName", handler)绑定。
  • 访问实例$("#elem").data("custom-counter")获取内部实例(高级用法)。
  • 命名空间:推荐使用自定义命名空间(如custom.ui.myapp.)避免冲突。
总结

在实际项目中,你使用 Widget Factory 的常见场景是:

  • 需要对官方小部件进行小改动(如给 Tabs 加关闭按钮、给 Datepicker 加节假日高亮)。
  • 需要创建项目专用的可复用组件(如表单验证提示、加载按钮、富文本工具栏)。

Widget Factory 提供了统一、一致、可继承的开发方式,让你的自定义组件与 jQuery UI 原生组件无缝融合,并自动享有主题支持、事件系统、状态管理等优势。

如果您有具体需求(如扩展某个官方部件的完整代码),告诉我,我可以提供针对性的实现示例!

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

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

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

作者头像 李华
网站建设 2026/5/16 15:07:20

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

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

作者头像 李华
网站建设 2026/5/1 8:24:50

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

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

作者头像 李华
网站建设 2026/5/21 15:11:51

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

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

作者头像 李华
网站建设 2026/5/22 9:14:53

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 是一个功能强大且易…

作者头像 李华
网站建设 2026/5/22 19:24:49

Open-AutoGLM Python调用终极教程(含完整示例代码下载)

第一章&#xff1a;Open-AutoGLM Python调用入门 Open-AutoGLM 是一个面向自动化任务的开源大语言模型工具&#xff0c;支持通过 Python SDK 快速集成自然语言理解与生成能力。开发者可利用其简洁的接口实现文本推理、指令解析和多轮对话等功能。 环境准备 在开始调用前&#…

作者头像 李华