XPages:TabPanel的OnClick

时间:2013-06-04 10:02:07

标签: xpages lotus-domino xpages-ssjs

我的xpage上有一个选项卡式面板,我想要实现的是如果用户切换选项卡,那么应该保存当前选项卡数据,因为我已经在tabPanel的onClick上编写了代码,但这会阻止任何进一步的服务器端代码运行

示例代码:

<xp:tabbedPanel id="tabbedPanel1">
   <xp:tabPanel label="Tab1" id="tabPanel1">
     <xp:label id="label1" value="Good Morning"></xp:label>
   </xp:tabPanel>
   <xp:tabPanel label="Tab2" id="tabPanel2">
    <xp:eventHandler event="onclick" submit="true" refreshMode="complete">
     <xp:this.action><![CDATA[#{javascript:print("Click on Tab2");}]>
      </xp:this.action>
    </xp:eventHandler>
     <xp:label id="label2" value="Good Afternoon"></xp:label>
   </xp:tabPanel>
   <xp:tabPanel label="Tab3" id="tabPanel3">
    <xp:label id="label3" value="Good Evening"></xp:label>
   </xp:tabPanel>
</xp:tabbedPanel>

问题:单击tabPanel2(具有onClick事件代码)后,服务器端停止响应,甚至Tab键切换停止。

感谢。

1 个答案:

答案 0 :(得分:1)

我知道这有点有线解决方案,但尝试使用jsonRpcService从ClientSide调用保存。

因此,您可以在客户端的每个点击onClick事件中添加一个函数,它不会阻止ServerSide标签功能。

<xp:text value="#{viewScope.save}"></xp:text>

<xp:tabbedPanel id="tabbedPanel1" selectedTab="tabPanel1">
    <xp:tabPanel label="Tab1" id="tabPanel1"
        onclick="saveDokumentHelper.save();">
        <xp:label id="label1" value="Good Morning"></xp:label>
    </xp:tabPanel>
    <xp:tabPanel label="Tab2" id="tabPanel2"
        onclick="saveDokumentHelper.save();">
        <xp:label id="label2" value="Good Afternoon"></xp:label>
    </xp:tabPanel>
    <xp:tabPanel label="Tab3" id="tabPanel3"
        onclick="saveDokumentHelper.save();">
        <xp:label id="label3" value="Good Evening"></xp:label>
    </xp:tabPanel>
</xp:tabbedPanel>

<xe:jsonRpcService id="jsonRpcService1"
    serviceName="saveDokumentHelper" state="true">
    <xe:this.methods>
        <xe:remoteMethod name="save">
            <xe:this.script><![CDATA[currentDocument.save();
viewScope.put("save","saved");]]></xe:this.script>
            </xe:remoteMethod>
        </xe:this.methods>
    </xe:jsonRpcService>

记住它只是一种可能性,我想到它可能会有一些问题。我只使用viewScope变量测试它,它可以工作。我还没有用Document.save方法测试它。