news 2026/2/9 17:00:16

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/2/5 10:29:04

Python Web开发效率革命:传统vs快马AI对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 生成一个性能对比测试项目&#xff1a;1) 传统方式手动编写的Flask博客系统 2) AI生成的同等功能Flask博客系统。两者都包含用户管理、文章发布、评论功能。输出两者的代码行数对比…

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

检测与防护CVE-2016-1000027的实用工具推荐

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 生成一个工具推荐列表&#xff0c;详细介绍可用于检测和防护CVE-2016-1000027漏洞的工具&#xff0c;包括开源工具和商业工具。每个工具应包含功能介绍、使用方法和适用场景。点击项…

作者头像 李华
网站建设 2026/2/6 7:08:22

终极解密:AdGuardHome如何用百万规则实现微秒级域名过滤

你是否曾好奇&#xff0c;当你的设备向AdGuardHome发起DNS查询时&#xff0c;这个看似简单的应用如何在瞬间完成对海量过滤规则的匹配&#xff0c;同时保持响应速度毫秒级&#xff1f;这背后隐藏着一套精密的过滤引擎设计&#xff0c;让我们一探究竟。&#x1f680; 【免费下载…

作者头像 李华
网站建设 2026/2/7 18:31:13

效率对比:传统排查vs快马AI解决conda报错

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个效率对比工具&#xff0c;功能&#xff1a;1. 模拟传统排查流程计时 2. 记录AI解决耗时 3. 生成对比图表 4. 计算时间节省百分比 5. 支持导出测试报告。要求使用PythonMatp…

作者头像 李华
网站建设 2026/2/7 9:58:02

Prism框架+AI:如何用快马自动生成WPF模块化代码

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 使用Prism框架创建一个WPF模块化应用程序&#xff0c;要求包含以下功能&#xff1a;1)主Shell窗口包含顶部菜单栏和内容区域&#xff1b;2)实现模块化加载机制&#xff0c;至少包含…

作者头像 李华