0

我需要一个在 ace:dataTable 中对列进行排序的示例,我不知道如何使用 sortBy + sortFunction 。谢谢

4

2 回答 2

2

所以我的朋友找到了解决方案:

在 collectionBean 中:

private Comparator<String> vNoComparator = new Comparator<String>(){ 

         public int compare(String iRec1, String iRec2){
              if(iRec1==null || iRec2==null)
              {
                    if(iRec1==null && iRec2==null)
                          return 0;
                    if(iRec1==null)
                          return -1;
                    return 1;
              } 

              long vNumber1=  Long.parseLong(iRec1) ;
              long vNumber2= Long.parseLong(iRec2);
              if(vNumber1>vNumber2)
                    return 1;
              else if(vNumber1<vNumber2)
                    return -1;
              else        
                    return 0; 
        }
  };

Comparator 的类型是我们排序的属性的类型,在这种情况下 ARecordNo 类型是 String

public Comparator<String> getvNoComparator() {
        return vNoComparator;
  }
  public void setvNoComparator(Comparator<String> vNoComparator) {
        this.vNoComparator = vNoComparator;
  }

在 .xhtml 中:

  <ace:dataTable
  value="#{eITDocumentsCollectionBean.AEITDocumentsItems}"
  var="eITDocumentsItemBean" …..
  <ace:column
  headerText="#{eITDocumentsCollectionBean.ARecordNumberColumnName}"
  sortBy="#{eITDocumentsItemBean.ARecordNo}" 
  sortFunction="#{eITDocumentsCollectionBean.vNoComparator}">

ARecordNo= ItemBean 中按它排序的属性 vNoComparator= 我创建的比较器

于 2012-05-02T13:45:30.207 回答
0

<ui:param name="title" value="#{msgs[dataTableSorting.title]}"/>
<ui:param name="description" value="#{msgs[dataTableSorting.description]}"/>
<ui:param name="resourceValue" value="#{dataTableSorting.exampleResource}"/>

<ui:param name="wikiResources" value="#{dataTableResources.wikiResources}"/>
<ui:param name="tldResources" value="#{dataTableResources.tldResources}"/>

<ui:define name="example">
    <h:form id="form">
       <ace:dataTable id="carTable"
                      value="#{dataTableSort.carsData}"
                      var="car">
           <ace:column id="id" headerText="ID" sortBy="#{car.id}">
                <h:outputText id="idCell" value="#{car.id}"/>
            </ace:column>
            <ace:column id="name" headerText="Name" sortBy="#{car.name}">
                <h:outputText id="nameCell" value="#{car.name}"/>
            </ace:column>
            <ace:column id="chassis" headerText="Chassis" sortBy="#{car.chassis}" >
                <h:outputText id="chassisCell" value="#{car.chassis}"/>
            </ace:column>
            <ace:column id="weight" headerText="Weight (lbs)" sortBy="#{car.weight}">
                <h:outputText id="weightCell" value="#{car.weight}"/>
            </ace:column>
            <ace:column id="accel" headerText="Accel" sortBy="#{car.acceleration}" >
                <h:outputText id="accelCell" value="#{car.acceleration}"/>
            </ace:column>
            <ace:column id="mpg" headerText="MPG" sortBy="#{car.mpg}">
                <h:outputText id="mpgCell" value="#{car.mpg}"/>
            </ace:column>
            <ace:column id="cost" headerText="Cost" sortBy="#{car.cost}">
                <h:outputText id="costCell" value="#{car.cost}">
                    <f:convertNumber type="currency"
                                     currencySymbol="$"
                                     groupingUsed="true"
                                     minFractionDigits="2"
                                     maxFractionDigits="2"/>
                </h:outputText>
            </ace:column>
        </ace:dataTable>
    </h:form>
</ui:define>

参考 - icefaces-showcase

于 2012-05-02T05:46:31.940 回答