Organizing Styles: Using SASS Partials for a Modular CSS Setup

How you choose to organize your styles can affect your efficiency as a front-end developer (how long it takes you to write code? how much code do you re-use from project to project? ), your ability to manage complex projects and work with others (how readable is your code? how easily can others understand it?), and how fast your site loads (how how much of that code is actually needed? do you always make time to refactor and optimize your code?).

This may not be a big concern for small static brochure sites, but as you work on larger, more complex projects with multiple designers/developers, style organization becomes essential. One solution is to separate your styles into smaller parts (partials) and then use a preprocessor (SASS) to compile the styles into one style.css.

There are several ways to learn SASS and multiple different approaches to setting up your projects and your CSS architecture, so below are a few different ways to go about it.


Sassy Base

Hands-on Activity #1: Sassy Sitebase From Scratch

Outcomes:

  • Spin up a local webserver from a dev environment (as opposed to using an IDE)
  • Auto-reload a browser whenever a file is saved without a manual refresh.
  • Auto-compile SASS (via a compiler/task manager that watches for changes)
  • Use SASS features to set up a modular style base for a small site (using SASS partials)

Steps:

  1. Setup a local front-end web development environment to compile SASS. In this step, we will use a Prepros, a GUI-based front-end compiler. In another lesson, we will use Gulp.
  2. Establish a custom organizational file system using SASS partials that embrace best practices and strategies from popular CSS methodologies (e.g. SMACSS).
  3. Embrace Components by working on small, bite-sized pieces of code that will work together to form a larger, modular system consisting of multiple SASS partial files. The new SCSS files will embrace SASS features to improve the coding experience, such as variables and nesting.

Instructions:

All instructions are embedded into the content of the "Sassy Base" site that you will be building (see the instuctions on the home page).

Examples:


Hands-on Activity #2: Convert a Static Site to a Sassy Site

In this hands-on activity (initially done as an in-class exercise in 2018), we will code a simple, single page brochure site from scratch using a multi-file SASS development system (that ebraces SASS features such as variables, partials, and nesting) to auto-generate a single-file CSS site that is ready for production. The end product, a single “compiled” style.css file, will be minified and ready for production. The new "Sassy CSS" system (a scss folder with partials) and new workflow (using a local dev environment with a pre-processor) will provide a faster, more efficient way to write cleaner, more maintainable code that is re-usable and a more powerful, flexible way to export and deploy project styles.

In this hands-on activity (initially done as an in-class exercise in 2017), we will work backwards: using a stylesheet for a small brochure site, we will convert a single-file CSS system into an organized multi-file SASS system. The end product, a “compiled” style.css file, should be no different than it was in the beginning. However, the new organizational system (scss folder with partials) and new workflow (using a local dev environment) will provide a faster, more efficient way to write code, a cleaner, more maintainable code base that is re-usable, and a more powerful, flexible way to export and deploy project styles.

Outcomes:

  • Spin up a local web server from a dev environment (as opposed to using an IDE)
  • Auto-reload a browser whenever a file is saved without a manual refresh.
  • Auto-compile SASS (via a compiler/task manager that watches for changes)
  • Use SASS features to set up a modular style base for a small site (using SASS partials)

Steps:

  1. Setup a local front-end web development environment to compile SASS. In this step, we  will use a Prepros, a GUI-based front-end compiler. In another lesson, we will use Gulp.
  2. Establish a custom organizational file system using SASS partials that embraces best practices and strategies from popular CSS methodologies (e.g. SMACSS).
  3. Convert the CSS to SASS by reverse engineering the original, singular CSS file and separating it into a modular system of multiple SASS partial files. The new SCSS files will embrace SASS features to improve the coding experience, such as variables and nesting.

Step One

Download Starter Files

  1. You can start with your own static base (e.g. in a previous lesson, you might have already created a static "My Base 1.0" based on Site Base 1.0) that you already may have already created on your own. If not,  you can download the provided sitebase1.zip or sitebase-static-css.zip and expand it in a local folder on your computer
  2. Rename the project folder to sitebase-sassy
  3. Rename style.css to style-orig.css
  4. Create a new folder named “scss”
    • Inside of scss, create a new file names style.scss
      • Add a $text-color variable and set the body color to the variable

Setup a Local Environment using Prepros

  1. Add sitebase-sassy project into prepros (drag & drop folder)
  2. Test sass compiling by editing style.scss
    • Ensure that a new style.css file is created and that the text turns red
  3. Use prepress “preview” to fire up a local web server

Step Two

Create SASS Partials

  1. Inside of your scss folder, create a new folder named “partials”
  2. In your editor, open up style-orig.css for reference (e.g. on the right)
  3. Open up style.scss (e.g. on the left)
  4. We are going to take css from the right and copy-paste it into new .scss files that we will create from scratch.

Link SASS Partials via @import

  • Change the root stylesheet (style.scss) to import base (_base.scss)
    • @import "base";
      • Note: the @import statement does not include the underscore "_"
    • optional: add site-specific comments after the base
  • Create, then import all partials into "base"
    • Start by creating/adding variables (_variables.scss)
    • Then import it into base
      • @import "variables";
  • Order of files to create/add/import into base:
    • base.scss
      1. @import "variables";
      2. @import "partials/toc-base";
      3. @import "partials/html5";
      4. @import "partials/typography";
      5. @import "partials/media";
      6. @import "partials/components";
      7. @import "partials/layout";
      8. @import "partials/structure";
      9. @import "partials/site-navigation";
      10. @import "partials/site-navigation-togglenav";

In the end, your project folder look like this:

 sitebase-sassy/ 
 └── css/
     ├── style.css (compiled/generated - OK to delete to test) 
 └── scss/
     ├── style.scss
     ├── _variables.scss
     ├── _base.scss
     ├── partials/
         ├── _toc-base.scss
         ├── _html5.scss
         ├── _typography.scss
         ├── _media.scss
         ├── _components.scss
         ├── _layout.scss
         ├── _structure.scss
         ├── _site-navigation.scss
         ├── _site-navigation-togglenav.scss 

You can also reference the folder structure and list of partial SCSS files via the end/completed lesson files here:

Step Three

Copy & Paste from CSS to SCSS

  1. Working from the top to the bottom, copy and paste css from style.css into the appropriate scss partial files.
  2. As you copy and paste, convert the CSS to SCSS to embrace the following SASS features:
    • Variables: create new variables for any duplicate values
    • Nesting: nest and indent selectors when appropriate
  3. Test as you code

Customize

When you are done, you are welcome to customize this base and make it your own. For example, if you saved your static version as "My Base 1.0" then consider naming this new base to "My Base 2.0" and uploading it to github for future reference. Here are two such repositories from John Doe:

Related Reading

Lesson Resources: