dijit.Dialog样例及其原型关系

本文探讨Dojo的dijit.Dialog对话框组件,通过分析样例代码及其JavaScript原型关系,深入理解其工作原理。dijit.Dialog可通过继承创建复杂功能的自定义对话框。示例展示了如何声明和使用自定义对话框,并利用原型链定制显示和隐藏行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Dojo中dijit.Dialog对话框控件由于其良好的设计和封装,得到了很多人的喜爱。而通过继承dijit.Dialog类,我们也可以设计出内在逻辑复杂,功能各异的各种自定义对话框。

本文通过分析两个样例及其JavaScript原型之间的关系,来更深入地了解dijit.Dialog是如何工作的。其中原型关系图参考了Dmitry A. Soshnikov 的“JavaScript. The Core. ”(中文版:“JavaScript核心指南 ”)一文。

样例代码如下:

其中,test.dialog是继承自dijit.Dialog的自定义对话框对象,tdlg和<div "showdialog">是test.dialog的两个实例。

下面是原型关系图:

1. Widget test.dialog继承了dijit.Dialog,而后者也继承了很多层不同的Dojo object。因此test.dialog可以使用或覆盖继承链上的绝大部分变量和方法。比如通过重写show()方法和hide()方法,可以自定义对话框显示和隐藏时的额外行为。

2. “test.dialog”做为构造函数名,可以用于构造Widget test.dialog实例。比如tdlg就是这样定义的。而在HTML中通过声明dojoType="test.dialog",也可以达到定义Widget test.dialog实例的作用。

3. 根据图上箭头所指的关系,可以从一个结点访问到路径上的其他结点(这儿__proto__的写法仅限于Mozilla。用Firebug console在Firefox中可以查看到)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值