arrow left
Back to Developer Education

    Getting Started with Angular 11 Routing

    Getting Started with Angular 11 Routing

    Web applications nowadays are user-friendly and convenient to use. If you are here, you probably may have heard of Single Page Applications (SPA). These are applications that work inside browsers and do not require page refresh during navigations. Normally, these pages are loaded once while their contents are dynamically added. <!--more-->

    Introduction

    An example of a SPA is Section, indicated by forwarding slashes followed by navigation content. For example, all articles on this platform are located on https://www.section.io/engineering-education/.

    This tutorial will walk you through the process of creating your Angular application using Routers. We'll learn the basics of Router outlets, navigations, routes, and paths to generate a complete Angular Single Page Application (SPA).

    For you to be able to follow this tutorial along, it'll be a necessity to have basic knowledge of Angular.

    Getting started with Angular router

    Angular Router is a core part of Angular that aids in building a single-page application. It's located in the @angular/router package.

    It has a complete routing library for constructing multiple route outlets. It also supports several features such as lazy loading and routing guards for access control et cetera.

    Routes and paths

    Routes are objects. At the lowest level, they comprise Angular components and paths, and sometimes redirectTo. This provides more details about a specific route plus a component to load on navigation. Paths are part URLs that are used to locate a resource.

    An example of a route:

    ----------------------------
    { 
      path:  '',
      component:  myDashboardComponent,
    },
    { 
      path:  'myPath',
      component:  MyPathComponent
    }
    ------------------------------
    
    

    You'll notice that these routes contain at least a path associated with its component.

    The Angular router-outlet

    Router-Outlet is an Angular directive from the router library that is used to insert the component matched by routes to be displayed on the screen.

    It's exported by the RouterModule and added to the template as shown below:

    <router-outlet></router-outlet>
    
    

    Angular route guards

    In our web applications, there are resources that we usually restrict their access to authenticated users only. This feature is made possible by Angular using the route guards.

    Let's look at an example:

    import { Injectable } from '@angular/core';
    import {CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree, Router} from '@angular/router';
    import { Observable } from 'rxjs';
    import { AuthService } from '@app/core/services';
    
    @Injectable({
      providedIn: 'root'
    })
    export class AuthGuard implements CanActivate
    {
      constructor(private router: Router, private authService: AuthService) {  }
      
      canActivate(
        route: ActivatedRouteSnapshot,
        state: RouterStateSnapshot): Observable<boolean | UrlTree> | Promise<boolean | UrlTree> | boolean | UrlTree
      {
        const user = this.authService.user;
        if (user)
        {
          // user authentication successful
          return true;
        }
        // authentication failed, redirect user to login page
        this.router.navigate(['/login']);
        return false;
      }
    }
    
    

    In this authentication guard script, we implemented the CanActivate while overriding the canActivate() method returning a boolean.

    If it returns, and access is allowed to the component, otherwise the user is redirected to the login page.

    Normally, we create navigation links in HTML using the <a href='#'>link</a> tags. In an Angular application, href in the <a> tag is replaced with the routerLink as shown below:

    <a routerLink="'/testLink'">my Angular Link</a> //
    <a routerLinkActive="'/testLink'">my Angular Link</a> // for active links
    

    Routing in action

    Now that we have got the basics of Angular routing, let's create a single application page.

    Step 1: Generate a new Angular project

    In this step, let's create a simple Angular application, 'routing-example' by running the following command on the terminal:

    ng new routing-example
    
    

    This prompts you to answer Yes/No questions as shown below:

    // while creating a new angular project, these sets of questions are displayed.
    ---------------------
        ? Do you want to enforce stricter type checking and stricter bundle budgets in t
        he workspace?
          This setting helps improve maintainability and catch bugs ahead of time.
          For more information, see https://angular.io/strict No
        ? Would you like to add Angular routing? Yes
        ? Which stylesheet format would you like to use? (Use arrow keys)
        ❯ CSS 
          SCSS   [ https://sass-lang.com/documentation/syntax#scss                ] 
          Sass   [ https://sass-lang.com/documentation/syntax#the-indented-syntax ] 
          Less   [ http://lesscss.org                                             ] 
          Stylus [ https://stylus-lang.com  
    ----------------------
    

    Enter Yes for the Angular routing option to generate the routing module for our application.

    Generate components

    Since we're going to define routes using components, let's generate these components by running the following commands:

    cd routing-example
    ng g component my-dashboard && ng g component student
    
    

    Now, let's navigate to the app.routing-module.ts and update the routes as shown below:

    // app.routing-module.ts has the following contents
    
    import { NgModule } from '@angular/core';
    import { Routes, RouterModule } from '@angular/router';
    
    const routes: Routes = [
      {
        path: '',
        component: MyDashboardCompoent,
      },
      {
        path: 'students',
        component: studentComponent,
      },
      
    ];
    
    @NgModule({
    
      imports: [
          RouterModule.forRoot(routes)
      ],
      
      exports: [
          RouterModule
      ],
    })
    export class AppRoutingModule { }
    
    

    This line, import { Routes, RouterModule } from '@angular/router'; imports the Routes and RouterModule from the router package. We then declare the routes constant of type Routes, which we imported earlier. We've defined the paths with their respective components.

    In the @NgModule(), we import the RouterModule and pass it the routes we defined via the RouterModule.forRoot(routes) method. We then make this RouterModule accessible by other modules by exporting it.

    Setting up router outlet

    Now that we've defined our application routes, let's now add the Router-Outlet to our main application template, app.component.html as seen below:

    <h4>My First Single page application</h4>
    <router-outlet></router-outlet>
    
    

    Next, import the app. routing-module in the app. module.

    --------------------------------------
    import { AppRoutingModule } from './app-routing.module';
    import { AppComponent } from './app.component';
    import { StudentComponent } from './app.component';
    import { MyDashboardComponent } from './app.component';
    @NgModule({
      declarations: [
        AppComponent,
        MyDashboardComponent,
        StudentComponent
      ],
      imports: [
        ---------------
        AppRoutingModule
      ],
      providers: [],
      bootstrap: [AppComponent]
    })
    export class AppModule { }
    
    

    You've reached this far? Congratulations, now let's serve our application:

    cd routing-example
    ng serve
    

    This will start your application on port 4200 by default or the immediate port if 4200 is in use. You can now navigate to this route and test your routes.

    Conclusion

    In this tutorial, we've discussed the powerful Angular routing tool. We discussed how we can define routes and build a complete single-page application.

    We've discussed other Angular routing concepts such as router outlets, paths, and routes. We also introduced the concept of Angular routing guards, by looking at an example of user authentication.

    Happy coding!


    Peer review contribution by: Odhiambo Paul

    Published on: Jun 3, 2021
    Updated on: Jul 15, 2024
    CTA

    Cloudzilla is FREE for React and Node.js projects

    Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
    Get Started for Free