The function of Angular routing is to realize page jump and view switching in single-page applications. 1. The basic routing function can be realized by introducing RouterModule and Routes, configuring the routing table in the root module or using lazy loading method to load in the module, 2. Use the router-outlet tag to specify the display location of the routing component, and implement local page updates through the routerLink instruction; 3. Dynamic routing can be defined by adding parameters (such as /user/:id) to the path and injecting ActivatedRoute into the component; 4. Nested routing defines the child routing structure through the children attribute, and the parent component needs to add router-outlet to display the child routing content.
The purpose of Angular routing is to enable page jumps and view switching in single page applications (SPA), just like traditional multi-page applications. Instead of refreshing the entire page, it loads different component content according to the URL.
How to configure basic routing
To use routing in Angular, you must first introduce RouterModule
and Routes
. You can configure the routing table in the root module (AppModule), or you can load it in modules by lazy loading.
One of the simplest routing configurations is as follows:
const routes: Routes = [ { path: 'home', component: HomeComponent }, { path: 'about', component: AboutComponent }, { path: '', redirectTo: '/home', pathMatch: 'full' } ];
Then register these routes in the module using RouterModule.forRoot(routes)
. In this way, when you access /home
or /about
, you can see the corresponding component content.
Use router-outlet to display routing content
Angular routing will not automatically display the components, you need to add the <router-outlet>
tag to the HTML template. This tag is where the routing component needs to be inserted.
For example, write in the AppComponent
template:
<nav> <a routerLink="/home">Home</a> <a routerLink="/about">About</a> </nav> <router-outlet></router-outlet>
After clicking on the link, HomeComponent
or AboutComponent
will be displayed in <router-outlet>
location.
-
routerLink
is used to replace the<a href="">
directive to avoid page refresh - The URL changes after clicking, but the page is only partially updated
Dynamic routing and getting parameters
Sometimes you want the path to take parameters, such as /user/123
, and you need dynamic routing. You can define the path like this:
{ path: 'user/:id', component: UserComponent }
Then inject ActivatedRoute
into the component to get the parameters:
constructor(private route: ActivatedRoute) {} ngOnInit() { this.route.params.subscribe(params => { console.log(params['id']); }); }
This method is suitable for scenarios where data needs to be loaded according to URL parameters, such as user details pages, article pages, etc.
How to deal with nested routes
If you have a structure like /user/123/profile
, you need to have nested routes. children
attribute can be set in the main path to define the subroutine:
{ path: 'user/:id', component: UserComponent, children: [ { path: 'profile', component: ProfileComponent }, { path: 'settings', component: SettingsComponent } ] }
At this time, the parent component (UserComponent) also needs a <router-outlet>
to display the content of the child route.
Basically that's it. Angular routing functions are very complete, from simple jump to lazy loading, guarding, and redirection, but the above basic operations can already meet the needs of most projects.
The above is the detailed content of Explain Angular routing. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

ToimplementdarkmodeinCSSeffectively,useCSSvariablesforthemecolors,detectsystempreferenceswithprefers-color-scheme,addamanualtogglebutton,andhandleimagesandbackgroundsthoughtfully.1.DefineCSSvariablesforlightanddarkthemestomanagecolorsefficiently.2.Us

The topic differencebetweenem, Rem, PX, andViewportunits (VH, VW) LiesintheirreFerencepoint: PXISFixedandbasedonpixelvalues, emissrelative EtothefontsizeFheelementoritsparent, Remisrelelatotherootfontsize, AndVH/VwarebaseDontheviewporttimensions.1.PXoffersprecis

Choosing the correct display value in CSS is crucial because it controls the behavior of elements in the layout. 1.inline: Make elements flow like text, without occupying a single line, and cannot directly set width and height, suitable for elements in text, such as; 2.block: Make elements exclusively occupy one line and occupy all width, can set width and height and inner and outer margins, suitable for structured elements, such as; 3.inline-block: has both block characteristics and inline layout, can set size but still display in the same line, suitable for horizontal layouts that require consistent spacing; 4.flex: Modern layout mode, suitable for containers, easy to achieve alignment and distribution through justify-content, align-items and other attributes, yes

CSSHoudini is a set of APIs that allow developers to directly manipulate and extend the browser's style processing flow through JavaScript. 1. PaintWorklet controls element drawing; 2. LayoutWorklet custom layout logic; 3. AnimationWorklet implements high-performance animation; 4. Parser&TypedOM efficiently operates CSS properties; 5. Properties&ValuesAPI registers custom properties; 6. FontMetricsAPI obtains font information. It allows developers to expand CSS in unprecedented ways, achieve effects such as wave backgrounds, and have good performance and flexibility

ReactivitytransforminVue3aimedtosimplifyhandlingreactivedatabyautomaticallytrackingandmanagingreactivitywithoutrequiringmanualref()or.valueusage.Itsoughttoreduceboilerplateandimprovecodereadabilitybytreatingvariableslikeletandconstasautomaticallyreac

CSSgradientsenhancebackgroundswithdepthandvisualappeal.1.Startwithlineargradientsforsmoothcolortransitionsalongaline,specifyingdirectionandcolorstops.2.Useradialgradientsforcirculareffects,adjustingshapeandcenterposition.3.Layermultiplegradientstocre

InternationalizationandlocalizationinVueappsareprimarilyhandledusingtheVueI18nplugin.1.Installvue-i18nvianpmoryarn.2.CreatelocaleJSONfiles(e.g.,en.json,es.json)fortranslationmessages.3.Setupthei18ninstanceinmain.jswithlocaleconfigurationandmessagefil

In Vue, provide and inject are features for directly passing data across hierarchical components. The parent component provides data or methods through provide, and descendant components directly inject and use these data or methods through inject, without passing props layer by layer; 2. It is suitable for avoiding "propdrilling", such as passing global or shared data such as topics, user status, API services, etc.; 3. Note when using: non-responsive original values ??must be wrapped into responsive objects to achieve responsive updates, and should not be abused to avoid affecting maintainability.
