- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
当以编程方式(使用绑定(bind)和 valExp)创建惰性数据表时,sortField 始终为 null,sortorder Ascending,filters map {}。即单击排序字段或在筛选字段中键入字符串。
当没有绑定(bind)的情况下完成相同的操作时,所有内容都在 xhtml View 中,一切都像宣传的那样工作。我还查看了 PhaseListener 的加载顺序,但在这两种情况下都没有发现任何不同之处,只是一开始它不起作用。
TestController 是@ViewScoped。尝试使用 PF 版本 3.5、3.4.2、3.3.1、3.3。
我做错了吗?
查看
<p:dataTable binding="#{testController.datatable}" />
<p:dataTable value="#{testController.testModel}" var="val" rows="5" lazy="true">
<p:column sortBy="#{val}">
#{val}
</p:column>
</p:dataTable>
世代
datatable = new DataTable();
datatable.setValueExpression("lazy",createValueExpression("true", Boolean.class));
datatable.setValueExpression("rows",createValueExpression("10", Integer.class));
datatable.setValueExpression("value",createValueExpression("#{testController.testModel}", DataModel.class));
datatable.setVar("val");
Column column = new Column();
column.setValueExpression("sortBy", createValueExpression("#{val}", String.class));
HtmlOutputText output = (HtmlOutputText) application.createComponent(HtmlOutputText.COMPONENT_TYPE);
output.setValueExpression("value", createValueExpression("#{val}", String.class));
column.getChildren().add(output);
datatable.getChildren().add(column);
模型
public List<String> load(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String, String> filters) {
List<String> modelMock = new ArrayList<String>() {
{
add("abc");
add("def");
}
};
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("load()");
}
if (LOGGER.isDebugEnabled()) {
LOGGER.debug("first " + first + " pageSize" + pageSize);
LOGGER.debug("sortField -> " + sortField);
LOGGER.debug("sortOrder -> " + sortOrder);
LOGGER.debug("filters -> " + filters);
}
this.setRowCount(modelMock.size());
return modelMock;
}
调试输出
11:12:24,426 DEBUG TestModel:33 - load()
11:12:24,426 DEBUG TestModel:37 - first 0 pageSize10
11:12:24,426 DEBUG TestModel:39 - sortField -> null
11:12:24,426 DEBUG TestModel:40 - sortOrder -> ASCENDING
11:12:24,426 DEBUG TestModel:41 - filters -> {}
第二个数据表证明当它不与绑定(bind)一起使用时,它是有效的
11:21:25,677 DEBUG TestModel:33 - load()
11:21:25,677 DEBUG TestModel:37 - first 0 pageSize5
11:21:25,677 DEBUG TestModel:39 - sortField -> val
11:21:25,677 DEBUG TestModel:40 - sortOrder -> DESCENDING
最佳答案
“binding”元素和“@ViewScoped”范围之间存在问题。您可以在此处阅读更多信息:http://balusc.blogspot.com/2010/06/benefits-and-pitfalls-of-viewscoped.html#HeyTheresPitfallsInTheTitle
一个解决方案,如果你想保留你的绑定(bind)和你当前的范围是为组件启用完整的状态保存。您可以通过将其添加到您的 web.xml
来为指定页面设置它<context-param>
<!-- For Bug Fixing Viewscope beans with binding component attributes -->
<param-name>javax.faces.FULL_STATE_SAVING_VIEW_IDS</param-name>
<param-value>/faces/myPageWithBindings.xhtml</param-value>
</context-param>
关于java - 以编程方式创建时,Primefaces Datatable sortField null 和过滤器映射 {},我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15199363/
你能帮我理解这个片段集吗: 首先好像是加了一个排序规则 MainSheet.Sort.SortFields.Clear For lI = 1 To vSortKeys(0, 1) Main
我正在使用 Jooq 进行分页。数据按多个字段排序,其中之一是字段上的自定义函数。例如,我有一个像这样的 SortField: DSL.coalesce(TABLE.COLUMN, 0).asc()
当以编程方式(使用绑定(bind)和 valExp)创建惰性数据表时,sortField 始终为 null,sortorder Ascending,filters map {}。即单击排序字段或在筛选
我正在尝试从 MySQL 表中选择一个随机记录列表,但优先考虑某些 ENUM 类型。当我在终端中运行以下纯 SQL 查询时,它工作正常: select * from table_name where
我是一名优秀的程序员,十分优秀!