gpt4 book ai didi

java - 为什么这个dataTable sortBy 函数不起作用?

转载 作者:行者123 更新时间:2023-11-29 06:14:49 25 4
gpt4 key购买 nike

我一直在尝试修复此数据表(Primefaces 组件)的 sortBy 函数,但我只是不明白为什么它不起作用,而其他功能(如分页或过滤器)可以正常工作。对于这个数据表,我只需要为它的名为“value”的标签属性传递一个数组,并为名为“var”的标签属性传递一个与数组类型相同的单个对象。下面我将发布我的代码。

这是带有数据表的 JSF 页面

<!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:ui="http://java.sun.com/jsf/facelets"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:t="http://myfaces.apache.org/tomahawk"
xmlns:p="http://primefaces.prime.com.tr/ui">
<ui:composition template="WEB-INF/templates/BasicTemplate.xhtml">
<ui:define name="resultsForm">
<h:form enctype="multipart/form-data">
<h:inputText id="search" value="" /><h:commandButton value="search"/>

<p:dataTable var="garbage" value="#{resultsController.allGarbage}" dynamic="true" paginator="true" paginatorPosition="bottom" rows="10"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
rowsPerPageTemplate="5,10,15">

<p:column filterBy="#{garbage.filename}" filterMatchMode="startsWith" sortBy="#{garbage.filename}" parser="string">
<f:facet name="header">
<h:outputText value="Filename" />
</f:facet>
<h:outputText value="#{garbage.filename}" />
</p:column>

<p:column filterBy="#{garbage.description}" filterMatchMode="contains">
<f:facet name="header">
<h:outputText value="Description" />
</f:facet>
<h:outputText value="#{garbage.description}" />
</p:column>

<p:column sortBy="#{garbage.uploadDate}" parser="string">
<f:facet name="header">
<h:outputText value="Upload date" />
</f:facet>
<h:outputText value="#{garbage.uploadDate}" />
</p:column>
</p:dataTable>
</h:form>
</ui:define>

这里是与该页面交互的托管 bean:

@ManagedBean
@RequestScoped
public class ResultsController {

@EJB
private ISearchEJB searchEJB;

private Garbage garbage;

public List<Garbage> getAllGarbage() {
return searchEJB.findAllGarbage();
}

public Garbage getGarbage() {
return garbage;
}

public void setGarbage(Garbage garbage) {
this.garbage = garbage;
}

访问数据库的EJB:

@Stateless(name = "ejbs/SearchEJB")
public class SearchEJB implements ISearchEJB {

@PersistenceContext
private EntityManager em;
public List<Garbage> findAllGarbage() {
Query query = em.createNamedQuery("findAllGarbage");
List<Garbage> gList = new ArrayList<Garbage>();

for (Object o : query.getResultList()) {
Object[] cols = (Object[]) o;
Garbage tmpG = new Garbage();
tmpG.setFilename(cols[0].toString());
tmpG.setDescription(cols[1].toString());
tmpG.setUploadDate(cols[2].toString());

gList.add(tmpG);
}
return gList;
}

正在使用 JPQL 命名查询的实体:

    @NamedQuery(name = "findAllGarbage", query = "SELECT g.filename, g.description,    g.uploadDate FROM Garbage g;")
@Entity
public class Garbage {

@Id
@GeneratedValue
@Column(nullable = false)
private Long id;
@Column(nullable = false)
private String filename;
@Column(nullable = false)
private String fileType;
@Column(nullable = false)
private String uploadDate;
@Column(nullable = false)
private String destroyDate;
@Lob
@Column(nullable = false)
private byte[] file;
@Column(nullable = false)
private String description;

带有浏览器输出的打印屏幕

enter image description here

页面刷新时的控制台输出(严重:第 1:61 行在字符“;”处没有可行的替代方案):

enter image description here

最佳答案

将 ResultsController 的范围更改为 @ViewScoped。 ResultsController 和 Garbage 对象将需要实现 java.io.Serializable。


也许这会有所帮助。以下是我开始工作的代码:

index.xhmtl

<?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:f="http://java.sun.com/jsf/core"
xmlns:p="http://primefaces.prime.com.tr/ui">
<f:view contentType="text/html" >
<h:head>
<title>PrimeFacesTest</title>
</h:head>
<h:body>
<h:form>
<p:dataTable var="garbage" value="#{indexBean.allGarbage}"
dynamic="true" paginator="true" paginatorPosition="bottom" rows="4"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
rowsPerPageTemplate="5,10,15">

<p:column filterBy="#{garbage.filename}" filterMatchMode="startsWith" sortBy="#{garbage.filename}" >
<f:facet name="header">
<h:outputText value="Filename" />
</f:facet>
<h:outputText value="#{garbage.filename}" />
</p:column>

<p:column filterBy="#{garbage.description}" filterMatchMode="contains" >
<f:facet name="header">
<h:outputText value="Description" />
</f:facet>
<h:outputText value="#{garbage.description}" />
</p:column>

<p:column sortBy="#{garbage.uploadDate}" parser="string">
<f:facet name="header">
<h:outputText value="Upload date" />
</f:facet>
<h:outputText value="#{garbage.uploadDate}" />
</p:column>
</p:dataTable>

</h:form>

</h:body>
</f:view>
</html>

IndexBean.java

@ManagedBean
@ViewScoped
public class IndexBean implements Serializable {

private ArrayList allGarbage;

public IndexBean() {
allGarbage = new ArrayList();
allGarbage.add(new Garbage("Abc", "Abc", "28/03/2011 12:13:32"));
allGarbage.add(new Garbage("Bbc;", "bbc", "28/03/2011 12:14:32"));
allGarbage.add(new Garbage("Cbc", "Cbc", "28/03/2011 12:17:32"));
allGarbage.add(new Garbage("1Abc", "1Abc", "28/03/2011 12:13:32"));
allGarbage.add(new Garbage("2Bbc;", "2bbc", "28/03/2011 12:14:32"));
allGarbage.add(new Garbage("3Cbc", "3Cbc", "28/03/2011 12:17:32"));
allGarbage.add(new Garbage("4Abc", "4Abc", "28/03/2011 12:13:32"));
allGarbage.add(new Garbage("5Bbc;", "5bbc", "28/03/2011 12:14:32"));
allGarbage.add(new Garbage("6Cbc", "6Cbc", "28/03/2011 12:17:32"));
}

public ArrayList getAllGarbage() {
return allGarbage;
}

}

垃圾.java

public class Garbage implements Serializable {

private String filename;
private String description;
private String uploadDate;

public Garbage(String filename, String description, String uploadDate) {
this.filename = filename;
this.description = description;
this.uploadDate = uploadDate;
}

public String getDescription() {
return description;
}

public void setDescription(String description) {
this.description = description;
}

public String getFilename() {
return filename;
}

public void setFilename(String filename) {
this.filename = filename;
}

public String getUploadDate() {
return uploadDate;
}

public void setUploadDate(String uploadDate) {
this.uploadDate = uploadDate;
}

}

关于java - 为什么这个dataTable sortBy 函数不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5484404/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com