[b]<a4j:keepAlive beanName="***Action" ajaxOnly="true"/>
此时把h:commandLink替换成a4j:commandLink即可[/b]
参考:dataTables的Action listener和action命令没有被调用?
如果action源(h:commandLink,h:commandButton)没有被提供,那么Action Listeners和actions就不会被激活。当action源在dataTable上时,并且dataTable的value属性指向一个请求范围的数据源,那么action源在接下来的请求中就没有被提供,例如:
action源没有被rendered,是因为数据源在随后的请求中不存在了(在第一次响应完成后,被垃圾回收器进行了回收)。
为了解决这个问题,使用t:saveState标记或者将request范围的bean放在session范围内:
此时把h:commandLink替换成a4j:commandLink即可[/b]
由于jsf的重构组件时保持状态的原理,造成commandlink未提交。
解决办法:在页面中加入:
<t:saveState value="#{后台bean名.datatable的list名}"/>
或者把后台bean名的范围改为session
<a4j:keepAlive beanName="***Action" ajaxOnly="true"/>
此时把h:commandLink替换成a4j:commandLink即可
或者在web.xml把javax.faces.STATE_SAVING_METHOD设置为client
参考:dataTables的Action listener和action命令没有被调用?
如果action源(h:commandLink,h:commandButton)没有被提供,那么Action Listeners和actions就不会被激活。当action源在dataTable上时,并且dataTable的value属性指向一个请求范围的数据源,那么action源在接下来的请求中就没有被提供,例如:
<h:dataTable value="#{requestScopedBean.dataModel.wrappedData}" />
<h:column>
<h:commandLink value="click here" action="#{backingBean.willNotFire}" />
</h:column>
</h:dataTable>
action源没有被rendered,是因为数据源在随后的请求中不存在了(在第一次响应完成后,被垃圾回收器进行了回收)。
为了解决这个问题,使用t:saveState标记或者将request范围的bean放在session范围内:
<t:saveState value="#{myRequestScopedBean.dataModel.wrappedData}" />