我有一个工具栏,应该允许用户选择汽车的品牌。使用重复控件中的var request scope变量来提取make。但是,当我尝试使用@DbLookup访问相应的值时,它无法返回任何内容。以下是代码段:
<xe:toolbar id="toolbar1" showButtonLabels="true">
<xe:this.treeNodes>
<xe:pageTreeNode label="Make">
<xe:this.children>
<xe:repeatTreeNode indexVar="index"
loaded="true" var="varValue">
<xe:this.value>
<![CDATA[#{javascript:@Unique(@DbColumn("", "parts list", 1))}]]>
</xe:this.value>
<xe:this.children>
<xe:pageTreeNode
label="#{javascript:varValue}">
<xe:this.children>
<xe:repeatTreeNode
indexVar="index1" loaded="true" var="varValue1">
<xe:this.value>
<![CDATA[#{javascript:@Unique(@DbLookup("", "parts list", requestScope.varValue, 2))}]]>
</xe:this.value>
<xe:this.children>
<xe:pageTreeNode
label="#{javascript:requestScope.varValue1}">
</xe:pageTreeNode>
</xe:this.children>
</xe:repeatTreeNode>
</xe:this.children>
</xe:pageTreeNode>
</xe:this.children>
</xe:repeatTreeNode>
</xe:this.children>
</xe:pageTreeNode>
<xe:pageTreeNode label="Vehicle">
</xe:pageTreeNode>
</xe:this.treeNodes>
<xp:eventHandler event="onItemClick" submit="true"
refreshMode="partial" refreshId="toolbar1">
</xp:eventHandler>
</xe:toolbar>
谁能告诉我哪里出错了?或者,如何才能访问第一个列表中所选项目的varValue变量?
我想要的一个例子是在以下链接的工具栏选项卡下: http://www.xpages.jp/demos/xpagesext.nsf/Core_Outline.xsp 另外,我是xpages的新手。谢谢你们。
答案 0 :(得分:0)
工具栏作为单个组件呈现到XPage组件树中。因此很难掌握任何价值观。当您在不同的上下文中渲染重复控件时,事情非常好。对于工具栏,您可以使用如下所示的丑陋黑客,或者使用重复在手动控件中渲染特定工具栏。我得到了这个样本:
<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core" xmlns:xe="http://www.ibm.com/xsp/coreex">
<xp:this.afterPageLoad><![CDATA[#{javascript:var result = new java.util.LinkedList();
var allMakes = @Unique(@DbColumn("", "parts list", 1));
for (var makeIndex in allMakes) {
var curModelName = allMakes[makeIndex];
var someModels = @Unique(@DbLookup("", "parts list", curModelName, 2));
if (someModels != null) {
result.offer(someModels);
result.offer(someModels);
}
}
viewScope.ModelsAndMakes = result; }]]></xp:this.afterPageLoad>
<xe:toolbar id="toolbar1" showButtonLabels="true">
<xe:this.treeNodes>
<xe:pageTreeNode label="Make">
<xe:this.children>
<xe:repeatTreeNode indexVar="indexMakes" loaded="true"
var="varMakes">
<xe:this.children>
<xe:pageTreeNode label="#{varMakes}">
<xe:this.children>
<xe:repeatTreeNode indexVar="indexModel"
loaded="true" var="varModel">
<xe:this.children>
<xe:pageTreeNode label="#{varModel}">
</xe:pageTreeNode>
</xe:this.children>
<xe:this.value><![CDATA[#{javascript:if (view.isRenderingPhase()) {
return viewScope.ModelsAndMakes.poll();
};}]]></xe:this.value>
</xe:repeatTreeNode>
<xe:basicLeafNode label="Fixed ende after">
</xe:basicLeafNode>
</xe:this.children>
</xe:pageTreeNode>
</xe:this.children>
<xe:this.value><![CDATA[#{javascript:@Unique(@DbColumn("", "parts list", 1))}]]></xe:this.value>
</xe:repeatTreeNode>
</xe:this.children>
</xe:pageTreeNode>
</xe:this.treeNodes>
<xp:eventHandler event="onItemClick" submit="true"
refreshMode="partial" refreshId="toolbar1">
</xp:eventHandler>
</xe:toolbar>
<ol>
<xp:repeat id="repeat1" rows="30" var="outerList" indexVar="outerIndex">
<xp:this.value><![CDATA[#{javascript:@Unique(@DbColumn("", "parts list", 1))}]]></xp:this.value>
<li>
<xp:text escape="true" id="computedField1" tagName="h3"
value="#{outerList}">
</xp:text>
<ol>
<xp:repeat id="repeat2" rows="30" var="innerList">
<xe:this.value>
<![CDATA[#{javascript:@Unique(@DbLookup("", "parts list", outerList, 2))}]]>
</xe:this.value>
<li>
<xp:text escape="true" id="computedField2" value="#{innerList}">
</xp:text>
</li>
</xp:repeat>
</ol>
</li>
</xp:repeat>
</ol>
</xp:view>
result.offer中的double条目是必要的,因为lifecyle轮询两次。正如我所说: 丑陋的黑客 让我们知道它是怎么回事。