我的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键切换停止。
感谢。
答案 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方法测试它。