2013-07-03 23 views
2

我目前正在使用Primefaces和treetables。除一例外,我的心臟起搏效果很好。讓我來一個小例子來說明這個問題:NumberFormatException PrimeFaces TreeTable

的treetable中是這樣的:

  • Item1.1
    • Item2.1
  • Item1.2
  • 項目1 .3

在開始時,樹是崩潰了。 的treetable中這樣定義:

<p:treeTable id="treetable" value="#{bean.root}" var="node" selectionMode="single" selection="#{bean.selectedNode}"> 

而且我在它的Ajax調用:

<p:ajax event="select" listener="#{bean.onSelect}" /> 

一切都在一般運行良好。無論節點的級別如何,所選節點都會更新。問題是這種情況:

(全部是摺疊)

  1. 延長Item1.1
  2. 選擇Item2.1
  3. 崩潰Item1.1
  4. 選擇Item1.2

在這裏,我得到了一個例外:

INFO: java.lang.NumberFormatException: For input string: "0,1" 
java.lang.NumberFormatException: For input string: "0,1" 
    at java.lang.NumberFormatException.forInputString(Unknown Source) 
    at java.lang.Integer.parseInt(Unknown Source) 
    at java.lang.Integer.parseInt(Unknown Source) 
    at org.primefaces.component.api.UITree.findTreeNode(UITree.java:120) 
    at org.primefaces.component.api.UITree.findTreeNode(UITree.java:129) 
    at org.primefaces.component.api.UITree.setRowKey(UITree.java:80) 
    at org.primefaces.component.treetable.TreeTableRenderer.decodeSelection(TreeTableRenderer.java:57) 
    at org.primefaces.component.treetable.TreeTableRenderer.decode(TreeTableRenderer.java:40) 
    at javax.faces.component.UIComponentBase.decode(UIComponentBase.java:787) 
    at org.primefaces.component.api.UITree.processDecodes(UITree.java:180) 
    at org.primefaces.component.treetable.TreeTable.processDecodes(TreeTable.java:325) 
    at com.sun.faces.context.PartialViewContextImpl$PhaseAwareVisitCallback.visit(PartialViewContextImpl.java:506) 
    at com.sun.faces.component.visit.PartialVisitContext.invokeVisitCallback(PartialVisitContext.java:183) 
    at org.primefaces.component.api.UITree.visitTree(UITree.java:402) 
    at javax.faces.component.UIComponent.visitTree(UIComponent.java:1623) 
    at javax.faces.component.UIForm.visitTree(UIForm.java:371) 
    at javax.faces.component.UIComponent.visitTree(UIComponent.java:1623) 
    at javax.faces.component.UIComponent.visitTree(UIComponent.java:1623) 
    at com.sun.faces.context.PartialViewContextImpl.processComponents(PartialViewContextImpl.java:376) 
    at com.sun.faces.context.PartialViewContextImpl.processPartial(PartialViewContextImpl.java:252) 
    at javax.faces.context.PartialViewContextWrapper.processPartial(PartialViewContextWrapper.java:183) 
    at javax.faces.context.PartialViewContextWrapper.processPartial(PartialViewContextWrapper.java:183) 
    at javax.faces.component.UIViewRoot.processDecodes(UIViewRoot.java:931) 
    at com.sun.faces.lifecycle.ApplyRequestValuesPhase.execute(ApplyRequestValuesPhase.java:78) 
    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 org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224) 
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169) 
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98) 
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407) 
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:987) 
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:579) 
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:309) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    at java.lang.Thread.run(Unknown Source) 
+0

'#{bean.selectedNode}'的類型是什麼? – user1983983

+0

該類型是一個TreeNode。 –

回答

0

這是PrimeFaces bug中的treetable.js,there is issue

的問題是因爲unselectAllNodes()在treetable.js功能不明確選擇數組變量,但它應該是空的從該函數退出後:

unselectAllNodes: function() { 
    var selectedNodes = this.tbody.children('tr.ui-state-highlight'); 

    for(var i = 0; i < selectedNodes.length; i++) { 
     this.unselectNode(selectedNodes.eq(i), true); 
    } 
} 

當父行與因爲所有可見的選定行(通過ui-state-highlight屬性進行搜索)取消選擇並從選擇數組變量。但是當父行被摺疊時,tbody.children *('tr.ui-state-highlight')*返回空列表,並且選擇數組變量具有以前的值加上以逗號分隔的新的可選值。

從PrimeFaces 4.0版本發佈此錯誤的好消息已修復。因爲this commit已被納入發佈。一個小的區別:選擇數組變量已被其他提交重命名爲選擇

unselectAllNodes: function() { 
    var selectedNodes = this.tbody.children('tr.ui-state-highlight'); 
    for(var i = 0; i < selectedNodes.length; i++) { 
     this.unselectNode(selectedNodes.eq(i), true); 
    } 

    this.selections = []; 
    this.writeSelections(); 
} 
+0

謝謝我會投票! –