Dojo单例模式之防止TabContainer实例化多次

本文介绍了在Dojo中,由于其组件未内置防止多次实例化的功能,因此需要手动实现单例模式以避免TabContainer在双击DataGrid列表时重复创建,从而保持界面整洁。

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

  现在单例模式越来越成熟了,很多编程语言通过组件的一个属性就可以防止模块被实例化多次,然而处于朝阳期发展的Dojo来说,并没有对它的组件实现这一功能。所以,在某些情况下,我们必须要手动控制防止一个Widget被实例化多次。今天我们就以TabContainer为例讲解如何防止Tab被实例化多次。

 

    问题:我们有如下一个Widget,当我们双击DataGrid中的列表时,来显示文档的详细信息,在“内容列表”右侧新创建一个Tab,显示文档的详细信息。如果我们不使用单例模式,每次双击都会新建一个Tab,很影响系统的界面展示。


    解决方案:
    Dojo的界面展示Html
<div data-dojo-type="dijit.layout.TabContainer" data-dojo-attach-point="tabContainer" data-dojo-props='region: "center"'>
	<div data-dojo-type="com.itccxx.core.dijit.searchlist.SearchList" 
 data-dojo-props='showToolbar: true,showNavigation: false, showPagination: true, showAllAction: false, searchBarName: "bpmDocumentSearch"' 
 data-dojo-attach-point="searchList" data-dojo-attach-event="onRowDblClick: onRowDblClick,onAction: _onAction"></div>
</div>

 Dojo单例模式解决方案:
定义全局变量openViewCach 。
var openViewCach = {};

onRowDblClick : function() {
   var item = this.getSearchList().searchList.getSelectedItem();
   console.dir(["item",item]);
   if(this.openViewCach[item.id[0]]){
       if(this.tabContainer.getIndexOfChild(this.openViewCach[item.id[0]]) != -1){
           this.tabContainer.selectChild(this.openViewCach[item.id[0]]);
           return ;
}
}
//查看DM中的文档详细信息
   tab = ecmwdgt.getBean("documentDataWidget", {
     title : item.recordChineseTitle,
     closable : true
});
   this.tabContainer.addChild(tab);
   this.tabContainer.selectChild(tab);
   var params = {
      id : item.id[0],
      bizCode : "DocumentManage"
};


   tab.openDocument(params);
   this.openViewCach[item.id[0]] = tab;
}

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值