我使用以下作为xpage重复控件的数据源:
var extDB = session.getDatabase("","Position.nsf");
var emailNVCollection:NotesViewEntryCollection = extDB.getView("PrincipalEmails").getAllEntries();
return emailNVCollection
我知道语法是正确的,因为答案为:Making a viewEntryCollection an objectDataSource
我无法弄清楚如何在计算字段中显示值。我尝试使用表达式语言简单绑定:rowHandle.fieldname。还有几个不同的javascript方法,比如我通过很多搜索找到的rowHandle.getColumnValue。他们都返回各种错误。使用javascript我认为我尝试过的方法对NotesViewEntryCollections无效。表达式语言方法返回:从lotus.domino.local.ViewEntry类型的bean获取属性“fieldname”时出错。
以下是实际来源:
<xp:panel style="margin-left:10.0px;margin-top:10.0px">
<xp:repeat id="repeat1" rows="30" var="rowHandle">
<xp:this.value><![CDATA[#{javascript:var extDB = session.getDatabase("","Position.nsf");
var emailNVCollection:NotesViewEntryCollection = extDB.getView("PrincipalEmails").getAllEntries();
return emailNVCollection}]]></xp:this.value>
<xp:text escape="true" id="computedField1"
value="#{rowHandle.posd_email}">
</xp:text>
</xp:repeat></xp:panel></:view>
我认为这应该很简单。照常。 ---莉莎&安培;
答案 0 :(得分:2)
您有NotesViewEntryCollection
作为重复值。
每个rowHandle
都是类NotesViewEntry的实例。
您可以使用getDocument()访问文档的项目。
rowHandle.getDocument().getItemValueString("yourItemName")
你的例子是
<xp:text escape="true" id="computedField1"
value="#{javascript: rowHandle.getDocument().getItemValueString('posd_email')>
</xp:text>
如果您像本例中的第一列一样使用view's column values,则性能会更好:
rowHandle.getColumnValues().firstElement().toString()
答案 1 :(得分:0)
你不想这样做。除了违背MVC范例之外,你还在呼唤性能问题。
虽然仍然以错误的方式摩擦MVC范例,但XPages使您能够摆脱底层数据库对象并使用其对应的包装器(在本例中为ViewEntry
到DominoViewEntry
)。 / p>
您必须先定义数据源(通常在页面开头声明):
<xp:this.data>
<xp:dominoView var="principalEmails" databaseName="Position.nsf"
viewName="PrincipalEmails" />
</xp:this.data>
然后在重复控件中引用数据源:
<xp:repeat id="repeatPrincipalEmails" value="#{principalEmails}" var="principalEmail">
<xp:text value="#{principalEmail.posd_email}" />
</xp:repeat>
只要您在点后定义的值对应于列编程名称 - 如果不涉及公式,该名称将自动匹配字段名称 - 您可以引用视图中的任何列。
如果您需要引用视图中不存在的任何其他字段,您可以做的最好的事情就是不要访问多米诺文档对象本身,而是添加另一个包含您需要的字段的列