ReusableTables

This project shows three different ways of working with tables in an Angular application:

  • generating a different component for each table, shown in DuplicateTablesModule,
  • using a single component accepting any type of data, shown in AnyTableModule,
  • using a truly generic component, shown in GenericTableModule.

In my opinion, the last one is the way to go: it leverages Typescript's Generics to ensure type safety, while still maximizing code reuse.

Running the code

This project was generated with Angular CLI version 7.1.4.

Development server

Run ng serve for a dev server. Navigate to http://localhost:4200/. The app will automatically reload if you change any of the source files.

Code scaffolding

Run ng generate component component-name to generate a new component. You can also use ng generate directive|pipe|service|class|guard|interface|enum|module.

Build

Run ng build to build the project. The build artifacts will be stored in the dist/ directory. Use the --prod flag for a production build.

Running unit tests

Run ng test to execute the unit tests via Karma.

Running end-to-end tests

Run ng e2e to execute the end-to-end tests via Protractor.

Further help

To get more help on the Angular CLI use ng help or go check out the Angular CLI README.