p:dataTable 没有找到记录
p:dataTable no records found
我在对话框中有一个数据 table。
当用户单击 Detail
link 时,应显示包含数据 table 的对话框。
代码如下:
<h:form>
<h:dataTable value="#{messageBean.messagesList}" var="msg">
<h:column>
<f:facet name="header">Detail</f:facet>
<p:commandLink action="#{messageBean.fetchSelectedMessage(msg.msgId)}" value="#{msg.summary}" />
</h:column>
</h:dataTable>
</h:form>
这是messageBean.fetchSelectedMessag(...)
:
@ManagedBean
@SessionScoped
public class MessageBean {
...
private List<Messages> messagesList;
private List<Messages> selectedMessage;
public void fetchSelectedMessage(String msgId) {
String sql = "SELECT * FROM messages WHERE msgId=?";
selectedMessage = jdbcTemplate.query(sql, new Object[]{msgId}, new BeanPropertyRowMapper<Messages>(Messages.class));
System.out.println("fetched selected message== " + selectedMessage); //correct
//open dialog sucucessfully
RequestContext context = RequestContext.getCurrentInstance();
context.execute("PF('dlg1').show();");
}
//getter/setters
然后这个对话框应该会打开(并且打开成功,但什么都不显示)
<p:dialog widgetVar="dlg1" modal="true" height="100">
<p:dataTable var="msg1" value="#{messageBean.selectedMessage}">
<p:column headerText="id">
<h:outputText value="#{msg1.msgId}"/>
</p:column>
<p:column headerText="to person">
<h:outputText value="#{msg1.toPerson}"/>
</p:column>
</p:dataTable>
</p:dialog>
为什么对话框数据table什么都显示不了?
selectedMessage
是 messages
类型的列表,不为空。
您需要在每次点击后更新对话框:
<p:commandLink ... process="@this" update=":msgForm:dlgPanel" onComplete="PF('dlg1').show();"/>
我在对话框中有一个数据 table。
当用户单击 Detail
link 时,应显示包含数据 table 的对话框。
代码如下:
<h:form>
<h:dataTable value="#{messageBean.messagesList}" var="msg">
<h:column>
<f:facet name="header">Detail</f:facet>
<p:commandLink action="#{messageBean.fetchSelectedMessage(msg.msgId)}" value="#{msg.summary}" />
</h:column>
</h:dataTable>
</h:form>
这是messageBean.fetchSelectedMessag(...)
:
@ManagedBean
@SessionScoped
public class MessageBean {
...
private List<Messages> messagesList;
private List<Messages> selectedMessage;
public void fetchSelectedMessage(String msgId) {
String sql = "SELECT * FROM messages WHERE msgId=?";
selectedMessage = jdbcTemplate.query(sql, new Object[]{msgId}, new BeanPropertyRowMapper<Messages>(Messages.class));
System.out.println("fetched selected message== " + selectedMessage); //correct
//open dialog sucucessfully
RequestContext context = RequestContext.getCurrentInstance();
context.execute("PF('dlg1').show();");
}
//getter/setters
然后这个对话框应该会打开(并且打开成功,但什么都不显示)
<p:dialog widgetVar="dlg1" modal="true" height="100">
<p:dataTable var="msg1" value="#{messageBean.selectedMessage}">
<p:column headerText="id">
<h:outputText value="#{msg1.msgId}"/>
</p:column>
<p:column headerText="to person">
<h:outputText value="#{msg1.toPerson}"/>
</p:column>
</p:dataTable>
</p:dialog>
为什么对话框数据table什么都显示不了?
selectedMessage
是 messages
类型的列表,不为空。
您需要在每次点击后更新对话框:
<p:commandLink ... process="@this" update=":msgForm:dlgPanel" onComplete="PF('dlg1').show();"/>