Using the Angular Router is one of the best ways to emulate multiple pages/screens in an Angular application. However, we might sometimes want even more flexibility by having the equivalent of “sub-pages” where sibling elements on a web page can display dynamic content based on the current URL.
Something like this where three different divs
can display different components without a parent/child relationship:
data:image/s3,"s3://crabby-images/12e3a/12e3ac5594ffc3411ed813058efc3d62417d67a1" alt=""
Angular allows us to have named router outlets to support such scenarios. We can define several sibling outlets by giving them distinctive names like so:
data:image/s3,"s3://crabby-images/d2887/d2887c1afc079f7a9d4dd82dee0b172010e24477" alt=""
Then, in our router config, we can define which component goes in which outlet for which path:
data:image/s3,"s3://crabby-images/75d1f/75d1fc3d963a2808436723bd4c6c7289ce33c616" alt=""
Finally, when routing a component to an outlet, we have to repeat some of that config in the form of a rather lengthy command:
data:image/s3,"s3://crabby-images/7ce82/7ce826bbcbe8975bbbe0673a16dcc407f7fba1b3" alt=""
The above code will load two different components in two different named outlets. You can see a live example on Stackblitz here.