2

I am using angularjs and ui-grid with custom cellTemplate. Each cell has an object as COL_FIELD. This object is passed to a function which returns image data uri used in src attribute of cellTemplate so each cell renders an image.

I have noticed that when I define the custom cellTemplate as following:

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

...Everything works BUT the functions for all cells and all rows are evaluated as the grid appears so it is slow to become responsive.

For testing purposes I tried the following cell template:

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

...This works in the sense I wish as only the cells within the viewport make the server call.

What is the reason for this difference? How can I have this second behaviour but with a function returning image data uri instead of a server call returning it. ANd have only the viewports cells request this as scrolled up or down?

Al Ex Tsm
  • 2,042
  • 2
  • 29
  • 47

1 Answers1

0

Why to not use base64 image especially when you use 30x30? in this case you don't need to call http requests at all

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

and:

{
   image: ""
}

Plunker

Maxim Shoustin
  • 77,483
  • 27
  • 203
  • 225
  • Yes that is what I am using, but I don´t wanna generate the `data:image/jpeg;base64` in advance cause my grid holds thousands of rows and at least 6-12 columns so generating them becomes slow.... That is why I was thinking of the function call returning the `data:image/jpeg;base6` but for some reason this function is called for all the rows all columns, not just the ones part of the viewport in a given moment – Al Ex Tsm Sep 29 '17 at 11:38
  • The image returned by my function is basically generated programatically. On the bases of the COL_FIELD object an offscreen `plotly.js` graph is generated, transformed to svg and then the `data:image/jpeg;base64` is returned. So doing this 2000X12 times in advance is not an option... – Al Ex Tsm Sep 29 '17 at 11:48