Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

what's the main diffrence style.scss vs style.module.scss?

I'm using react with sass.

It's look like both have same benefits. Locally scoped, No more conflict etc. What is the main diffrence between style.scss vs style.module.scss

Why do we need .module prefix?

like image 703
ryoshpa Avatar asked Dec 05 '25 17:12

ryoshpa


2 Answers

Short Answer

*.scss is normal SCSS file while *.module.scss is SCSS file with CSS modules.

According to the repo, CSS modules are:

CSS files in which all class names and animation names are scoped locally by default.

This solves the problem of typing ultra specific CSS class names to avoid clashes. Good bye .phone-page-contact-form-edit-card-default-button-blah-blah and hello .default-button

Usage

Below is the usage for *.scss

.ultra-specific-class-name_item {
  display: flex;
}

If you use SCSS in a normal way, you must declare the class name as a string

// Simply import
import './foo.scss';


const App = () => (
  <div className="ultra-specific-class-name_item">
    foo bar
  </div>
)

Below is the usage for *.module.scss

// No need of any ultra specific classnames 
.item {
  display: flex;
}

If you use SCSS as a CSS module, you must use them as how you would use a JS module.

// import as a js module 
import styles from './foo.module.scss';

const App = () => (
  <div className={styles.item}>
    foo bar
  </div>
)

Output

<!-- Normal SCSS -->
<!-- it will not be transformed -->
<div class="ultra-specific-class-name_item">foo bar</div>

<!-- SCSS with Class Module -->

<!-- hash values are suffixed to the class name -->
<div class="item-35ada5">foo bar</div>

<!-- newer versions will even prefix the file name
     to the class name -->
<div class="foo__item-35ada5">foo bar</div>
like image 186
Pushkin Avatar answered Dec 08 '25 06:12

Pushkin


I notice a difference that .module.scss prevents simple import

// does not work
import './foo.module.scss';

.module.scss forces you to import as module

// works
import styles from './foo.module.scss';

and I didn't find difference between below codes. (I didn't use features like composes)

import styles from './foo.module.scss';

import styles from './foo.scss';
like image 21
Pale Blue Dot Avatar answered Dec 08 '25 08:12

Pale Blue Dot



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!