JSF 2.0 및 Primefaces 3.4.2를 사용 중이며, 지연 성 부하를 사용하여 데이터 테이블을 채 웁니다.프라임 그래프 선택 가능한 행이 뷰 스코프를 사용하여 작동하지 않습니다.
managedbean의 범위를 볼 때 selectedRow 데이터 테이블은 널 포인터 예외를 제공합니다. 세션 범위를 사용하면 managedbean에서 selectedRow를 얻을 수 있습니다.
범위를 지정하는 데 CDI Spring 주석을 사용하고 있습니다. 뷰 범위를 만들려면 this 메서드를 사용했습니다.
내가 두 번째 페이지에 페이지를 매기는 경우 뷰 범위를 사용하는 다른 일을 발견하고 나는이 selectedRow를 얻을 수, 첫 페이지로 회복 한 1
업데이트. 페이지 매김없이 행을 선택하면 널 포인터 예외가 발생합니다.
JSF 페이지
<p:dataTable id="dataTable" var="req" lazy="true" value="#{emp.lazyModel}"
paginator="true" rows="10"
selection="#{emp.selectedRequest}"
selectionMode="single">
<p:ajax event="rowSelect" listener="#{emp.onRowSelect}" />
ManagedBean은
@Named("emp")
@Scope("view")
public class EmployeesManagedBean implements Serializable {
@PostConstruct
public void init() {
initTable();
}
private void initTable() {
lazyModel = new LazyRequestDataModel(requestList, requestService);
}
public LazyDataModel<Employee> getLazyModel() {
return lazyModel;
}
나는 onRowSelect
방법이 라인에서 nullpointer 예외를 얻고있다
Emp emp = (Emp) event.getObject());
System.out.println(emp.getEmpNo());
전체 오류 스택 트레이스
java.lang.NullPointerException
at net.test.managed.bean.RequestManagedBean.onRowSelect(RequestManagedBean.java:134)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at com.sun.el.parser.AstValue.invoke(AstValue.java:187)
at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:297)
at org.primefaces.component.behavior.ajax.AjaxBehaviorListenerImpl.processAjaxBehavior(AjaxBehaviorListenerImpl.java:52)
at org.primefaces.event.SelectEvent.processListener(SelectEvent.java:40)
at javax.faces.component.behavior.BehaviorBase.broadcast(BehaviorBase.java:106)
at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:760)
at javax.faces.component.UIData.broadcast(UIData.java:1071)
at javax.faces.component.UIData.broadcast(UIData.java:1093)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:794)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1259)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:593)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227)
at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125)
at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:301)
at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56)
at weblogic.servlet.internal.RequestEventsFilter.doFilter(RequestEventsFilter.java:27)
at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:56)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.wrapRun(WebAppServletContext.java:3730)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3696)
at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
at weblogic.security.service.SecurityManager.runAs(SecurityManager.java:120)
at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2273)
at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2179)
at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1490)
at weblogic.work.ExecuteThread.execute(ExecuteThread.java:256)
at weblogic.work.ExecuteThread.run(ExecuteThread.java:221)
그 문제를 계속 조사해야합니다. 결국 처음부터 제대로 작동하지 않을 것입니다. – Daniel
@ 대니얼 처음으로 선택한 행을 얻지 못하는 것에 대한 단서가 없습니다. – user75ponic
당신이 그 대답을 얻지 못한다면 프라임 폼에 대해 물어보십시오 ... – Daniel