2017-09-29 4 views
2

저는 angularjsui-grid을 주문 cellTemplate과 함께 사용하고 있습니다. 각 셀의 개체는 COL_FIELD입니다. 이 객체는 src 속성이 cellTemplateimage data uri을 반환하는 함수로 전달되어 각 셀이 이미지를 렌더링합니다.뷰포트에 렌더링 된 경우 속성 값에서 각도 ui-grid cellTemplate 함수를 독점적으로 평가하는 방법은 무엇입니까?

내가 발견 한 것을 나는 다음과 같은 사용자 정의 cellTemplate를 정의 할 때 :

<img src="{{grid.appScope.getCachedImg(COL_FIELD)}}" /> 

은 ... 모든 작동하지만 그리드가되기 위해 느린 때문에 나타나는 모든 셀과 모든 행에 대한 기능 평가 반응 형. 나뿐만 뷰포트 내에서만 세포가 서버 호출을 할 이것은 의미에서 작동 ...

<img src="https://dummyimage.com/30x30/000/fff&text={{COL_FIELD.attributes.displayName[0]}}" /> 

: 테스트 목적으로

나는 다음과 같은 세포 템플릿을 시도했다.

이 차이가 나는 이유는 무엇입니까? 어떻게이 두 번째 동작을 할 수 있지만 반환하는 서버 호출 대신 image data uri 반환하는 함수가 있습니다. 뷰포트 셀만 위 또는 아래로 스크롤하도록 요청 했습니까?

답변

0

특히 30x30을 사용하는 경우 base64 이미지를 사용하지 않는 이유는 무엇입니까? 이 경우 모든

<img src="{{COL_FIELD.image}}" /> 

에서 HTTP 요청을 호출 할 필요가없고 : 내가 사용하고 무엇을

{ 
    image: "" 
} 

Plunker

+0

예 즉,하지만 난 싶지하지는 데이터 그리드가 생성되기 전에 미리 grid에 수천 개의 행과 적어도 6-12 열을 저장하는 'data : image/jpeg; base64'를 생성해야합니다. 그래서 느리게 생성됩니다. 그래서'data : image/jpeg; base6'하지만 어떤 이유로이 함수가 호출되었습니다. 모든 행 모든 열, 주어진 순간의 뷰포트의 부분이 아닙니다. –

+0

내 함수에서 반환 된 이미지는 기본적으로 프로그래밍 방식으로 생성됩니다. COL_FIELD 객체를 기반으로하여 화면이 아닌'plotly.js' 그래프가 생성되고 svg로 변환 된 다음'data : image/jpeg; base64'가 반환됩니다. 따라서이 2000X12 배를 사전에 수행하는 것은 옵션이 아닙니다 ... –