clears multisort meta during pagination 中的惰性 ="true"-6ren"> clears multisort meta during pagination 中的惰性 ="true"-我刚刚在“DataTable - Lazy Loading”的展示代码中启用了多重排序 datatableLazy.xhtml CarDataTable -6ren">
gpt4 book ai didi

sorting - sortMode ="multiple"和

clears multisort meta during pagination 中的惰性 ="true"

转载 作者:行者123 更新时间:2023-12-04 08:49:36 29 4
gpt4 key购买 nike

我刚刚在“DataTable - Lazy Loading”的展示代码中启用了多重排序
datatableLazy.xhtml

<html lang="en" xmlns="http://www.w3.org/1999/xhtml"
xmlns:f="http://java.sun.com/jsf/core"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:p="http://primefaces.org/ui"
xmlns:ui="http://java.sun.com/jsf/facelets">
<h:head>
<title>CarDataTable</title>
</h:head>
<h:body>
<h:form id="form">
<p:dataTable var="car" value="#{tableBean.lazyModel}" paginator="true"
rows="10"
paginatorTemplate="{RowsPerPageDropdown} {FirstPageLink} {PreviousPageLink} {CurrentPageReport} {NextPageLink} {LastPageLink}"
rowsPerPageTemplate="5,10,15" id="carTable" lazy="true"
sortMode="multiple">

<p:ajax event="rowSelect" listener="#{tableBean.onRowSelect}"
update=":form:display" oncomplete="carDialog.show()" />

<p:column headerText="Model" sortBy="#{car.model}"
filterBy="#{car.model}">
<h:outputText value="#{car.model}" />
</p:column>

<p:column headerText="Year" sortBy="#{car.year}"
filterBy="#{car.year}">
<h:outputText value="#{car.year}" />
</p:column>

<p:column headerText="Manufacturer" sortBy="#{car.manufacturer}"
filterBy="#{car.manufacturer}">
<h:outputText value="#{car.manufacturer}" />
</p:column>

<p:column headerText="Color" sortBy="#{car.color}"
filterBy="#{car.color}">
<h:outputText value="#{car.color}" />
</p:column>
</p:dataTable>
</h:form>
</h:body>
</html>
TableBean.java
package com.solartis.primefaces.sample;

import java.util.ArrayList;
import java.util.List;
import java.util.UUID;

import javax.faces.bean.ManagedBean;

import org.primefaces.model.LazyDataModel;

@ManagedBean
public class TableBean {

private LazyDataModel<Car> lazyModel;

private Car selectedCar;

private List<Car> cars = new ArrayList<Car>();

private final static String[] colors;

private final static String[] manufacturers;

static {
colors = new String[10];
colors[0] = "Black";
colors[1] = "White";
colors[2] = "Green";
colors[3] = "Red";
colors[4] = "Blue";
colors[5] = "Orange";
colors[6] = "Silver";
colors[7] = "Yellow";
colors[8] = "Brown";
colors[9] = "Maroon";

manufacturers = new String[10];
manufacturers[0] = "Mercedes";
manufacturers[1] = "BMW";
manufacturers[2] = "Volvo";
manufacturers[3] = "Audi";
manufacturers[4] = "Renault";
manufacturers[5] = "Opel";
manufacturers[6] = "Volkswagen";
manufacturers[7] = "Chrysler";
manufacturers[8] = "Ferrari";
manufacturers[9] = "Ford";
}

public TableBean() {
populateRandomCars(cars, 50);
lazyModel = new LazyCarDataModel(cars);
}

public Car getSelectedCar() {
return selectedCar;
}

public void setSelectedCar(Car selectedCar) {
this.selectedCar = selectedCar;
}

public LazyDataModel<Car> getLazyModel() {
return lazyModel;
}

private void populateRandomCars(List<Car> list, int size) {
for (int i = 0; i < size; i++) {
list.add(new Car(getRandomModel(), getRandomYear(),
getRandomManufacturer(), getRandomColor()));
}
}

private String getRandomColor() {
return colors[(int) (Math.random() * 10)];
}

private String getRandomManufacturer() {
return manufacturers[(int) (Math.random() * 10)];
}

private int getRandomYear() {
return (int) (Math.random() * 50 + 1960);
}

private String getRandomModel() {
return UUID.randomUUID().toString().substring(0, 8);
}
}
LazyCarDataModel.java
package com.solartis.primefaces.sample;

import java.util.ArrayList;

/**
* Dummy implementation of LazyDataModel that uses a list to mimic a real
datasource like a database.
*/
public class LazyCarDataModel extends LazyDataModel<Car> {

private List<Car> datasource;

public LazyCarDataModel(List<Car> datasource) {
this.datasource = datasource;
}

@Override
public Car getRowData(String rowKey) {
for(Car car : datasource) {
if(car.getModel().equals(rowKey))
return car;
}

return null;
}

@Override
public void setRowIndex(int rowIndex) {

if (rowIndex == -1 || getPageSize() == 0) {
super.setRowIndex(-1);
} else
super.setRowIndex(rowIndex % getPageSize());
}

@Override
public Object getRowKey(Car car) {
return car.getModel();
}

@Override
public List<Car> load(int first, int pageSize,
List<SortMeta> multiSortMeta,Map<String, String> filters) {

System.out.println("\nTHE INPUT PARAMETER VALUE OF LOAD METHOD :
\t"+"first=" + first + ", pagesize=" + pageSize + ", multiSortMeta=" +
multiSortMeta + " filter:" + filters);

System.out.println("\nTHE MULTISORTMETA CONTENT : \t");

if (multiSortMeta != null) {
for (SortMeta sortMeta : multiSortMeta) {
System.out.println("SORTFIELD:" +sortMeta.getSortField());
System.out.println("SORTORDER:" +sortMeta.getSortOrder());
System.out.println("SORTFUNCTION:"
+sortMeta.getSortFunction());
System.out.println("COLUMN:" +sortMeta.getColumn());
System.out.println("CLASS:" +sortMeta.getClass());
}
}

List<Car> data = new ArrayList<Car>();

//filter
for(Car car : datasource) {
boolean match = true;

for(Iterator<String> it = filters.keySet().iterator(); it.hasNext();) {
try {
String filterProperty = it.next();
String filterValue = filters.get(filterProperty);
String fieldValue = String.valueOf(car.getClass().
getField(filterProperty).get(car));

if(filterValue == null || fieldValue.startsWith(filterValue)) {
match = true;
}
else {
match = false;
break;
}
} catch(Exception e) {
match = false;
}
}

if(match) {
data.add(car);
}
}


//rowCount
int dataSize = data.size();
this.setRowCount(dataSize);

//paginate
if(dataSize > pageSize) {
try {
return data.subList(first, first + pageSize);
}
catch(IndexOutOfBoundsException e) {
return data.subList(first, first + (dataSize % pageSize));
}
}
else {
return data;
}
}
}

它运行良好,除非我使用多列排序进行分页, load()方法与 List<SortMeta>load() 不同,没有给我当前排序以转移到其他页面的列详细信息方法与 String sortField, SortOrder sortOrder这给出了这些排序细节。

例如:
  • 点击“制造商”中的排序箭头,然后Ctrl+点击“年份”中的排序箭头
  • 你会得到排序列的详细信息到 load()方法(我已经在 load 方法中打印了输入参数值)。
  • 现在,做分页。这里load()方法无法提供排序列的详细信息
  • 不仅仅是分页,如果在点击排序列后输入列过滤值,同样存在问题

  • 我怎样才能解决这个问题?

    最佳答案

    我临时解决了这个问题...
    有一个 session 范围的托管 bean 用于存储排序列的详细信息,以便在分页期间进入 load(),
    喜欢:-

    @ManagedBean
    @SessionScoped

    public class StoreSortColumnDetail implements Serializable{


    /** holds multisort values**/
    private List<SortMeta> mMultiSortMeta;


    public List<SortMeta> getMultiSortMeta() {
    return mMultiSortMeta;
    }

    public void setMultiSortMeta(List<SortMeta> multiSortMeta) {
    mMultiSortMeta = multiSortMeta;
    }

    public void clearMultiSortMeta() {
    if(this.mMultiSortMeta != null)
    this.mMultiSortMeta.clear();

    }
    }

    并在 load() 中使用它,如下所示:
    @Override
    public List<Car> load(int first, int pageSize,
    List<SortMeta> multiSortMeta,Map<String, String> filters) {

    /** Instance to the SessionScoped scoped StoreSortColumnDetail managed bean*/
    @ManagedProperty(value="#{StoreSortColumnDetail }")
    private StoreSortColumnDetail storeSortColumnDetail ;

    public void setStoreSortColumnDetail (StoreSortColumnDetail sortColumnDetail ) {
    this.storeSortColumnDetail = sortColumnDetail ;
    }

    /** to hold the handled sort column detail**/
    List<SortMeta> handledMultiSortMeta = new ArrayList<SortMeta>();

    /*Here starts the multisortmeta handling process*/
    /** check for List<SortMeta> for null**/
    if(multiSortMeta != null ) {

    /** updates StoreSortColumnDetail's List<SortMeta> with Load()'s List<SortMeta>**/
    storeSortColumnDetail.setMultiSortMeta(multiSortMeta);
    handledMultiSortMeta = multiSortMeta;
    }
    /** check for List<SortMeta> for notnull **/
    else if (multiSortMeta == null) {

    /**assigns Load()'s List<SortMeta> with StoreSortColumnDetail's List<SortMeta>**/
    handledMultiSortMeta = storeSortColumnDetail.getMultiSortMeta();
    }


    /*Now u have handled multisortmeta from load()...
    and u can process now from handledMultiSortMeta*/
    }

    我希望你知道我是如何处理的,如果不是亲密的我......
    但这是一种临时方式,需要通过primefaces方式处理...

    关于sorting - sortMode ="multiple"和 <p :dataTable> clears multisort meta during pagination 中的惰性 ="true",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15469986/

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