I have an application using xamWebGrid and in the demo configuration it displays just 357 rows. The data are instances of a simple CLR object of 11 properties of value types: datetime (3), enum (2), string (2), int (2), bool (2).
The empty grid is displayed quickly but the time from setting the data source to displaying the data is ~5 seconds. Initially this is quite confusing for users who are unaware they should wait so press F5 to refresh the page. We've put in a "Loading..." message on screen to inform the user but there does not seem to be an event fired by the xamWebGird once the data is displayed. Without such an event we don't know when to remove the loading message.
So two questions: why the delay? There is not a lot of data. Secondly, is there an event that will fire once the display is presented?
Thanks
Bill Seddon
Hi, I am having similar problem, with a grid having 25 columns and about 100 rows. I have make following settings
<igGrid:XamWebGrid.RowSelectorSettings> <igGrid:RowSelectorSettings Visibility="Visible" EnableRowNumbering="True" > </igGrid:RowSelectorSettings> </igGrid:XamWebGrid.RowSelectorSettings> <igGrid:XamWebGrid.SelectionSettings> <igGrid:SelectionSettings ColumnSelection="Multiple" RowSelection="Multiple" ></igGrid:SelectionSettings></igGrid:XamWebGrid.SelectionSettings><igGrid:XamWebGrid.SortingSettings> <igGrid:SortingSettings AllowSorting="False"></igGrid:SortingSettings></igGrid:XamWebGrid.SortingSettings>
<igGrid:XamWebGrid.EditingSettings> <igGrid:EditingSettings AllowEditing="Cell" IsMouseActionEditingEnabled="DoubleClick" IsEnterKeyEditingEnabled="True" IsF2EditingEnabled="True" IsOnCellActiveEditingEnabled="False" /></igGrid:XamWebGrid.EditingSettings>
I am facing following problems:1. Overall application load time bit high about 20 seconds.2. Overall application response time is very slow.3. Keyboard typing in a cell is very slow. 4. Grid Scroll is very slow.
Furthermore, this issue is basically related with number of columns instead of number of rows. I've tested same program with 5 Columns and 10000 Rows without paging and it is working fine. No Keyboard event delays nor application response problem and significant change (better) load time but the same program causes problem with 30 rows with 25 columns.
Seems unlikely. However, *if* that's the case, I'll be looking for my money back. If the only way to obtain anything like acceptable performance on a grid with just 300 rows and 11 colums is to fix the size of the whole control (bearing in mind users might want to resize it to fit their browser and given the noise Infragistics is making about the performance when showing 1 million rows) then, in my view, the grid is not fit for purpose.
It's not clear if you are just another poster or if you work for Infragistics. Can you enlighten me?
Hi,
So, you don't have to explicitly set a Height and Width on the control, it works as everything in SL works. If you don't set a height and width, it inherits it's height and width from it's parent container.
My guess is that you're placing the xamWebGrid in a container that is giving it infinite height and width. When that happens, you're telling the grid to draw everything, which mean no virtualization can take place. So, this should be avoided. You'll see the same issue with ms's grid as well.
As for resizing, with your browser, then if the xamWebGrid's container is a Grid panel, then it will resize with the container, and still have a height and width. So virtualization will still take place.
-SteveZ
Guys you are missing the point. The 'whole' data is 300 rows by 11 columns - lets say 4000 cells (or less in Imran Zia's case). *Any* grid (including MS's because I've used it) does not pause for 5 seconds after the data source is set and before the data is displayed. Let's focus on the XamWebGrid and not try to be distracted by what may or may not be happening with some other grid.
But I'll another datapoint from further testing in response to these posts: I've set column widths and row heights to a fixed size and fixed the size of the control to 800x800 but it makes no difference. Also, the delay does not appear to be affected by the volume of data - 300 or 1500 records and the delay period is the same.
It *does* appear to be affected by the number of rows or columns in the available display area. That is, the number of cells. 34 rows x 11 coumns = ~ 5 seconds. 7 rows = 2 seconds.
Hi bseddon,
I don't have any solution to your problems, but I can tell you that you're not the only one expecting better performances. We also have major performance issue when a lot of columns are displayed in the grid.
Infragistics agreed to open a support case for the xamDataGrid 2-3 months ago ( CAS-34293-471OP8). That case refers to bad performance when expanding a record. This scenario illustrates very well that it takes too much time to display the data.
There is nothing you can do to speed it up on your side...
Hello,
The mentioned case and the related development issue regarding slow performance were created to find a way to improve the performance of the XamDataGrid when expanding a record. However, the reported scenario had a large number of fields (Columns) which results in inserting a great number of elements into the visual tree of the application, which is the main culprit in this issue.
So far, we were able to make some improvements on this matter. We have kept this issue opened in order to be able to go back to it, revisit it and try to find other ways for improvement.
We would appreciate if you can share any additional information on the scenario/ your environment that might be helpful.
Hi Steve
Thanks for the news about the performance improvements. We updated our software to use 10.1 and believe we are seeing an improvement in the time to render the display (after the data has been retrieved) from ~5 seconds to ~1 second. So good job.
Bill
Just as an update, 10.1 was released a couple days of ago, and we added a lot of performance improvements to the grid, specifically in loading. These enhancements weren't just made in 10.1, they will also be in our next 9.1 and 9.2 Service Releases.
And I hope anyone else experiencing an presentation performance issue also see an improvement bit I'm guessing you are looking at different problem.
We were alerted to the issue by a user (usinga publicly available release build) who had difficulties which arose from impatience at the time taken to display rows. We see no material difference in performance between release and debug builds.
I was amazed by how slow the grid was performing (running from Visual Studio). As a test, I published out the web site and ran it outside the debugger and it was SO MUCH FASTER !!
Hi Stephen,
I am not very much sure but I faced slow application response with SilverLight Standard DataGrid too. Is this some problem due to SilverLight architecture limitation like number of controls in Controls Tree or there is some other bug. Can you please elaborate?
If it is related with number of controls in Controls Tree then why it works fine with thousands of rows with 4 or 5 columns (I've seen your application demo with million rows but with paging). I have tested same solution without paging against 100 rows with 25 colunms (2,500 cells) and 10,000 rows with 5 colunms (50,000 cells) and observered that 25 columns have performance issue but 5 columns solution works fine.
Regards,
Imran