Logo

dev-resources.site

for different kinds of informations.

Module scoped styling in Angular 13

Published at
7/15/2022
Categories
angular
styling
Author
brunoelo
Categories
2 categories in total
angular
open
styling
open
Author
8 person written this
brunoelo
open
Module scoped styling in Angular 13

Angular convention provides us with the concept of modules typically used for grouping features in our applications. I heavily rely on this and as such, get into the dilemma of styling those modules when I want each module to have global styles that only affect all components in that particular module.

This article shows various ways of achieving module scoped styling in Angular.

You can jump to the stackblitz demo to check it out.

Application architecture

Firstly, let me describe the application architecture for these use cases.
We have an angular 13 application in a stackblitz which has the app module and 3 lazy-loaded modules with 2 components in each module.
The styles.scss global stylesheet has the style below which is applied across the entire application

body {
  color:red
}
Enter fullscreen mode Exit fullscreen mode

I will be using the colors of the paragraphs to show how you can leverage module scoped styling and what it entails.

Currently, this is what the color of the paragraphs in all components look like
module-one-first.png
module-one-second.png
module-two-first.png
module-two-second.png
module-three-first.png
module-three-second.png

Solution 1: Using the :host selector in the stylesheet of the module component

With this method, the :host selector is used to style the host element(app-module-one) and then the children(components) of the parent host element inherit the css property. The :host selector can also be combined with other selectors if you want to style the descendants of the host element.

We add this in module-one.component.scss

:host {
  color: blue;
}
Enter fullscreen mode Exit fullscreen mode

And now, every component in module one gets the styles
module-one-first-after.png
module-one-second-after.png

You can add more properties relating to font, background color e.t.c... that you want applied to all components of the module. Ideally inheritable css properties.

Solution 2: Creating a separate stylesheet for modules and importing it in components you need it in

It may be preferred to use an entirely separate stylesheet which is added in the styleUrls array of the components the styles should be applied to.

We'll create a stylesheet called module-two-styles.scss in the module-two directory (so it's easy to find) and add the style below.

/* module-two-styles.scss */

p {
  color: green;
}
Enter fullscreen mode Exit fullscreen mode

We're simply styling the p tag by giving the color property a value of green.

Then import the module-two-styles.scss in the first.component.ts, second.component.ts and module-two.component.ts files in module-two folder.

/* module-two/first/first.component.ts */

@Component({
  selector: 'app-first',
  templateUrl: './first.component.html',
  styleUrls: ['./first.component.scss','../module-two-style.scss']
})
Enter fullscreen mode Exit fullscreen mode
/* module-two/second/second.component.ts */

@Component({
  selector: 'app-second',
  templateUrl: './second.component.html',
  styleUrls: ['./second.component.scss','../module-two-style.scss']
})
Enter fullscreen mode Exit fullscreen mode
/* module-two/module-two.component.ts */

@Component({
  selector: 'app-module-two',
  templateUrl: './module-two.component.html',
  styleUrls: ['./module-two.component.scss','module-two-style.scss']
})
Enter fullscreen mode Exit fullscreen mode

Now this will only apply the style to the components you imported the stylesheet into.
module-two-first-after.png
module-two-second-after.png

Some reasons for doing this is sometimes, you may be working in a codebase that has the potential to be largely refactored while you're working on something or maybe you want to create some sort of easily manageable distinction between your styles and the ones that were already in the existing project and cannot afford to tamper with the global stylesheet as you consider the time constraints involved.

Tip for using styleUrls

The position of the stylesheet paths in the styleUrls array matters. Stylesheets get overridden by other stylesheets that come after them in the array.

Demo

Here is a stackblitz that contains a demo for the article. You can quickly explore and experiment more style properties.

Thank you for reading

Feel free to leave suggestions or questions in the comment especially if you have challenges with styling your application a certain way. Also share the article if you gained something or feel it was helpful.

Connect

If you would like to connect with me, I'm available on;

  • Discord: brunoelo#8120
  • Twitter: BrunoElo
styling Article's
30 articles in total
Favicon
Making Your CLI Applications Pop with Styled Outputs
Favicon
Decoding StyleX: Meta's Cutting-Edge Styling System
Favicon
Free Tailwind CSS Button Animations
Favicon
Styling in React
Favicon
Need Help With Z-Index/Positiong
Favicon
Styling in React: CSS-in-JS vs. Traditional CSS
Favicon
Panda CSS Conditions
Favicon
Styling Your Next.js Web Application
Favicon
DIV Class and CSS. A beginner explains.
Favicon
Personalizing MUI Stepper
Favicon
CSS's :root Variables. Use it!
Favicon
2 Style Patterns in React for Extended Component Styling
Favicon
Complete beginner's guide to using Styled Components with Nextjs and TypeScript
Favicon
Here, not there — or, making styling behave
Favicon
WHY TAILWIND CSS WHEN I HAVE BOOTSTRAP
Favicon
Darle estilo a un input file upload button <input type="file">
Favicon
Material UI vs Semantic UI vs Styled Components
Favicon
7 Tailwind CSS Tips I Wish I Knew Earlier
Favicon
Boost your styling with Bootstrap 🚀
Favicon
React Styling Methods
Favicon
Module scoped styling in Angular 13
Favicon
How to Detect User Color Preference in React Native
Favicon
CSS Styling Tricks: Flexbox
Favicon
CSS Styling Tricks: How to Build Responsive Web Applications with Percentages
Favicon
Here is why I switched from bootstrap to tailwind.
Favicon
Tailwind vs Sass/SCSS: Structure and Consistency over Style and Comfort
Favicon
What is calc() function in CSS ?
Favicon
Accent all areas
Favicon
CSS basic 3 - Units, Text Styling
Favicon
Pourquoi TailwindCSS est le meilleur moyen de styliser une page web ?

Featured ones: