AngularJS 1.x Grid
This page details how to set up ag-Grid inside and AngularJS 1.x application.
When the ag-Grid script loads, it does not register with AngularJS 1.x. This is because AngularJS 1.x is an optional part of ag-Grid and you need to tell ag-Grid you want to use it.
Download from Github
ag-Grid-Enterprise is also distributed as both a self contained bundle and also via a CommonJS package.
As with the ag-Grid example, all we need to do is reference the ag-grid-enterprise dependency and we're good to go:
Do not include both ag-Grid Community and ag-Grid-Enterprise self contained bundles. The ag-Grid-Enterprise bundle contains ag-Grid Community within it.
The creation of the Grid would be the same as the ag-Grid example above.
ag-Grid Enterprise Bundle Types
Again similar to ag-Grid, ag-Grid-Enterprise has 4 bundles:
Even if you are using React, AngularJS 1.x, Angular, VueJS or Web Components, the above is all you need to do. Any grid you create will be an enterprise grid once you load the library.
If using CommonJS, you one need to include ag-Grid-Enterprise into your project. You do not need to execute any code inside it. When ag-Grid-Enterprise loads, it will register with ag-Grid such that the enterprise features are available when you use ag-Grid.
Creating the AngularJS 1.x Module
Include ag-Grid as a dependency of your module like this:
To include a grid in your html, add the
ag-grid attribute to a div. The value
of the div should be the provided grid options on the scope.
It is also usual to provide a styling theme to
the grid. Three themes come with the grid,
ag-theme-material. Each one is
set by applying the corresponding class of the same name to the div.
You must provide width and height to your grid. The grid is programmed to fill the width and height you give it.
(note: a div by default has 100% width, so the width is not specified explicitly above).
The grid options provide ag-Grid with the details needed to render. At a minimum you should provide the columns (columnDefs) and the rows (rowData).
Basic AngularJS 1.x Example
Events & Digest Cycle
For AngularJS 1.x - ag-Grid does not not fire events inside an Angular JS digest cycle. This is done on purpose for performance reasons, as there are many events fired, even if you don't listen to them. Firing the digest cycle for each one would kill performance. So you may want to $scope.$apply() after you handle the event.
If using ag-Grid's AngularJS direction, you do not need to manually clean up the grid. The grid ties in with the AngularJS 1.x lifecycle and releases all resources when the directive is destroyed.
Advanced AngularJS 1.x Example
The below example has much more details. The mechanism for setting up the grid is the same as above. Don't worry about the finer details for now, how all the different options are configured is explained in the relevant parts of the documentation.
Angular 1.x and ag-Grid Components
ag-Grid does not provide direct support for it's components and
AngularJS 1.x. If you want to put custom
then need to manage creating and destroying child scopes yourself inside the
Below shows an example of using ag-Grid Filter, Header and Cell Renderer components. The following can be noted:
- The Make column has an Angular 1 Header Component.
- The Model column has an Angular 1 Filter.
- The Price column has an Angular 1 Cell Renderer.
- The Date column has an Angular 1 Cell Editor (using the AngularJS UI Bootstrap Directive).
- The Date column has an Angular 1 Date Filter (using the AngularJS UI Bootstrap Directive).
Each component creates it's own $scope in the
initmethod and destroys it in the
But maybe you are not worried about performance. Maybe you are not displaying that many rows and columns. And maybe you want to provide your own cell renderers and use Angular here. For whatever reason, it is possible to turn Angular on for Angular version 1.x.
When Angular is turned on in ag-Grid, every time a row is inserted, a new child Angular Scope is created for that row. This scope gets the row attached to it so it's available to any Angular logic inside the cell.
Each cell within the row does not get a new child scope. So if placing item inside the child scope for the row, be aware that it is shared across all cells for that row. If you want a cell to have it's own private scope, consider using a directive for the renderer that will introduce a new scope.
Turn On Angular Compile
Angular compiling is turned on by setting the grid options attribute angularCompileRows to true.
- angularCompileRows: Whether to compile the rows for Angular.
The default is always to have Angular compiling off for performance reasons.
Below then uses three columns rendered using custom Angular renderers.
- Athlete: Uses simple binding to display text.
- Age: Uses simple binding to display a button, with a button click event using ng-click.
- Country: Uses a custom Angular directive to display the country.
If using templateUrl, then the html is cached. The server is only hit once per template and it is reused.
The example below uses cell templates for the first three columns.
- Col 1 - The first column uses a static template. Pretty pointless as you can't change the content between rows.
- Col 2 - The second column uses an inline template. AngularJS 1.x is then used to fetch the content from the scope via ng-bind.
- Col 3 - The third column is similar to the second, with the difference that it loads the template from the server.
Ready to try ag-Grid in your project? Download ag-Grid Community edition or trial ag-Grid Enterprise for free.