I'm trying to get my Angular Table to refresh after updating the data used in the table.
The docs say "you can trigger an update to the table's rendered rows by calling its renderRows() method." but it is not like a normal child component where I can use something "@ViewChild(MatSort) sort: MatSort;" since I do not import it.
If I do import it and try something like @ViewChild('myTable') myTable: MatTableModule; then I get an error that says that renderRows() does not exist on that type.
How can I call this method? Thanks!
My table code snippet:
<mat-table #table [dataSource]="dataSource" myTable class="dataTable">
You're not supposed to query for the string. This will query the reference (defined like
<cmp #ref>
). Also the type is wrong: you're not grabbing a module from the view, you're grabbing a component.You should import the component you want to query and do the following (change according to which component exactly you need to query):
The argument in the
ViewChild
decorator is the component you want to query and the type is just for your convenience -- you could omit it or sayany
, but you won't have any help from TypeScript if you do not do it so it's recommended to leave it.Make sure you import ViewChild and MatTable:
Then you can get a reference to the table using the ViewChild (note that a type T is required on MatTable - I just used any, but if you have a typed table, you will need to use that type:
Then when you modify the table in any way you will need to call the renderRows() method.
Here is a very simple working example: https://stackblitz.com/edit/angular-bxrahf
Some sources I found when solving this issue myself: