SAP UI5中片段的重复ID错误

问题描述:

我已阅读大量关于销毁片段或页面的帖子以避免重复的ID,但这里的问题是片段显示在视图页面中,并且当我再次按下相同的按钮时我得到错误重复ID。SAP UI5中片段的重复ID错误

下面是片段和控制器代码:

<core:FragmentDefinition xmlns="sap.m" 
    xmlns:f="sap.ui.layout.form" xmlns:core="sap.ui.core" xmlns:mvc="sap.ui.core.mvc" 
    xmlns:html="http://www.w3.org/1999/xhtml" xmlns:l="sap.ui.layout"> 
<Page id="masterAp" showHeader="false" enableScrolling="true" >  
    <TileContainer 
     id="getTiles" 
     tiles="{myModel1>/0/TileCollection}"> 
     <StandardTile  
     title="{myModel1>title}" 
    icon="{myModel1>icon}" 
     number="{myModel1>number}" 
     numberUnit="{myModel1>numberUnit}" 
     info="{myModel1>info}" 
     infoState="{myModel1>infoState}" 
       press="handleTilePress"/>  
     </TileContainer> 
     </Page> 
</core:FragmentDefinition> 

的控制器代码:请指点什么行代码丢失,避免重复ID错误:未捕获的错误:错误:在添加元素与副本ID“ getTiles'

onPressGoToMaster1 : function() { 
    var oDialogFragment = sap.ui.xmlfragment("yca_web111_dashboard.fragments.panel2",this.getView().getController()); 
    var oModel = new sap.ui.model.json.JSONModel("data/dataAP.json"); 
    sap.ui.getCore().setModel(oModel, "myModel1"); 
    var oPage = this.getView().byId("detail"); 
    oPage.insertContent(oDialogFragment); 
    this.getSplitAppObj().to(this.createId("detail")); 

}; 

您试图在每次移动到页面时使用id:detail来添加片段。最简单的解决方案是检查你是否已经添加了片段。

  • 如果是(片段存在),请不要再次将片段添加到带有id:detail的页面,然后导航。
  • 如果否(片段不存在),获取片段,添加到页面并导航。

代码:

onPressGoToMaster1 : function() { 
    if (!this.oDialogFragment) { 
     this.oDialogFragment = sap.ui.xmlfragment("yca_web111_dashboard.fragments.panel2",this.getView().getController()); 
     var oModel = new sap.ui.model.json.JSONModel("data/dataAP.json"); 
     sap.ui.getCore().setModel(oModel, "myModel1"); 
     var oPage = this.getView().byId("detail"); 
     oPage.insertContent(this.oDialogFragment); 
    } 

    this.getSplitAppObj().to(this.createId("detail")); 

}; 
+0

谢谢....它的工作原理 – Chethan