2010-08-18 3 views
1

MySQL 데이터베이스의 정보를 표시하는 테이블을 만들고 있는데, 전 세계 어디에서나 foreignkeys를 사용하여 데이터를 상호 참조합니다.플렉스 - 행 레이블로 DataGrid 열 정렬

기본적으로 '시스템'이라는 열이있는 DataGrid가 있습니다. 시스템은 다른 테이블에있는 개체의 id을 나타내는 int입니다. lableFunction을 사용하여 둘을 상호 참조하고 열 이름을 바꿉니다. 하지만 이제 정렬이 작동하지 않습니다. 사용자 지정 정렬 함수를 만들어야한다는 것을 알고 있습니다. 나는 두 테이블을 다시 참조하기 위해 시도했지만, 그것은 약 30 초에 1200 개의 행을 정렬하는 데 걸린다. 지금 나는 내가 다음에 시도해야 할 것에 대해 단서가 없다.

정렬 기능에서 열 필드 레이블에 액세스 할 수있는 방법이 있습니까?

public function order(a:Object,b:Object):int 
{ 
    var v1:String = a.sys; 
    var v2:String = b.sys; 
    if (v1 < v2){ 
     trace(-1); 
     return -1; 
    }else if (v1 > v2){ 
     trace(1); 
     return 1; 
    }else { 
     trace(0); 
     return 0; 
    } 
}

답변

1

이 문제를 처리하는 한 가지 방법은 수신 한 객체를 거쳐 상호 참조 ID를 기반으로 각 객체에 레이블을 속성으로 추가하는 것입니다. 그런 다음 레이블 기능을 사용하는 대신 데이터 격자 열에 표시 할 레이블 속성을 지정할 수 있습니다. 그런 식으로 자신 만의 정렬 기능을 만들 필요없이 원하는대로 정렬 할 수 있습니다.

+0

나는 이것이 내가해야 할 일이라고 생각한다. 모든 데이터를 분리하여 보관하려고했지만 그럴 일은 없을 것이라고 생각합니다. 나는 그것을 시도 할 것이다. – noazark

+0

투시력을 가져 주셔서 감사합니다. 상황이 그렇게 잘 작동하는 것 같습니다. 기본적으로 테이블에서 모든 테이블을 별도로 유지하고 있습니다 (robotlegs 사용). 테이블이 업데이트되면 교차 참조 필드를 테이블 행에 추가하는 메서드가 호출됩니다. 나는 여분의 지연 (있을 경우)이 많다는 것을 눈치 채지 못하고있다. 다시 한 번 감사드립니다. – noazark

0

DataGrids 및 기타 목록 기반 클래스의 작동 방식은 itemRenderers를 사용하는 것입니다. 렌더러는 화면에 표시된 데이터에 대해서만 작성됩니다. 대부분의 경우 dataProvider에는 화면에 표시되는 것보다 훨씬 많은 데이터가 있습니다.

dataGrid에 표시된 데이터를 기반으로 데이터를 정렬하려고하면 원하는 결과를 얻지 못할 가능성이 큽니다.

그러나 sortFunction에서 데이터 객체에 대해 동일한 레이블 함수를 호출 할 수있는 이유는 없습니다.

한 가지 방법은 데이터 그리드의 itemToLabel 기능을 사용하는 것입니다

var v1:String = dataGrid.itemToLabel(a); 
var v2:String = dataGrid.itemToLabel(b); 

두 번째 방법은 명시 적으로의 labelFunction 호출하는 것입니다 :로 정렬 내가 찾은 내 경험에

var v1:String = labelFunction(a); 
var v2:String = = labelFunction(b); 

매우 빠르지 만 레코드 세트는 보통 한 번에 메모리에로드하는 것보다 약간 큽니다.