我有一个数据表
<p:dataTable id="db"
value="#{notificationBox.notificationsList}"
var="notificationForm"
rows="15"
emptyMessage="${msgs.getMessage('table.empty.message')}"
paginator="true"
paginatorPosition="bottom"
rowKey="#{notificationForm}"
selection="#{notificationBox.notification}"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} ( ${notificationBox.notificationsList.size()} ${msgs.getMessage('table.records')} )"
selectionMode="single"
tableStyle="height:430px">
//Rest of the code
在这里,如果我选择任何行,我将进行 ajax 调用(与 primefaces 即时行选择示例相同)。 Ajax 位于 Datatable 内部。
<p:ajax event="rowSelect" listener="#{notificationBox.onRowSelect}"
oncomplete="carDialog.show();" />
我的支持 Bean 类 -
private List<NotificationForm> notificationsList;
public NotificationForm notification;
public void onRowSelect(SelectEvent event) {
LOGGER.info("Here. +"+notification);
}
//Setter and Getters.
问题是,如果我选择任何行,“通知”将为空。我无法进一步处理。请帮忙。也欢迎任何替代方法。
Edit:-
我的托管 Bean 范围 -
<managed-bean>
<managed-bean-name>notificationBox</managed-bean-name>
<managed-bean-class>com.comviva.workflow.ui.notification.NotificationBox</managed-bean-class>
<managed-bean-scope>view</managed-bean-scope>
<managed-property>
<property-name>notificationDao</property-name>
<value>#{notificationDaoService}</value>
</managed-property>
<managed-property>
<property-name>userInfoDao</property-name>
<value>#{userInfoDaoProxy}</value>
</managed-property>
</managed-bean>
你有你的p:dataTable
包裹在一个h:form
标签?这实际上对我有用:
通知框(@ViewScoped)
package com.mycompany;
import java.util.Arrays;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import org.primefaces.event.SelectEvent;
@ManagedBean
@ViewScoped
public class NotificationBox {
public class NotificationForm {
Integer notificationId;
String name;
public NotificationForm(Integer id, String nam) {
notificationId = id;
name = nam;
}
public String getName() {
return name;
}
public Integer getNotificationId() {
return notificationId;
}
@Override
public String toString() {
return "NotificationForm [notificationId=" + notificationId
+ ", name=" + name + "]";
}
}
private List<NotificationForm> notificationsList;
public NotificationForm notification;
public NotificationBox() {
notificationsList = Arrays.asList(new NotificationForm(1, "Form1"),
new NotificationForm(2, "Form2"));
}
public NotificationForm getNotification() {
return notification;
}
public List<NotificationForm> getNotificationsList() {
return notificationsList;
}
public void onRowSelect(SelectEvent event) {
System.out.println(event.getObject());
}
public void setNotification(NotificationForm notification) {
this.notification = notification;
}
}
索引.xhtml
<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui"
xmlns:ui="http://java.sun.com/jsf/facelets"
xmlns:f="http://java.sun.com/jsf/core">
<h:head>
</h:head>
<h:body>
<h:form>
<p:dataTable id="db" value="#{notificationBox.notificationsList}"
var="notificationForm" rows="15"
emptyMessage="${msgs.getMessage('table.empty.message')}"
paginator="true" paginatorPosition="bottom"
rowKey="#{notificationForm.notificationId}"
selection="#{notificationBox.notification}"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} ( ${notificationBox.notificationsList.size()} ${msgs.getMessage('table.records')} )"
selectionMode="single" tableStyle="height:430px">
<p:ajax event="rowSelect" listener="#{notificationBox.onRowSelect}" />
<p:column>
#{notificationForm.name}
</p:column>
</p:dataTable>
</h:form>
</h:body>
</html>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)