The Build!
In this final step, we'll add one more script, which will execute the entire process!
We'll cover the following
Final build #
Lets now write one final script to run everything at once!
Add the following line of code:
"build-css": "npm-run-all compile-sass concat-css prefix-css compress-css"
And our final package.json
looks like so:
"scripts": {
"watch-sass": "node-sass sass/main.scss css/style.css --watch",
"compile-sass": "node-sass sass/main.scss css/style.comp.css",
"concat-css": "concat -o css/style.concat.css css/additional.css css/style.comp.css",
“prefix-css”: “postcss --use autoprefixer -b 'last 5 versions' css/style.concat.css -o css/style.prefix.css”,
"compress-css": "node-sass css/style.prefix.css css/style.css --output-style compressed",
"build-css": "npm-run-all compile-sass concat-css prefix-css compress-css"
},
Here, we’ve simply added all our tasks compile-sass
, concat-css
, prefix-css
& compress-css
to be run when we execute our build command.
We use the npm-run-all package to ensure it works on all platforms.
Enter the following command:
npm install npm-run-all --save-dev
Let’s run a final test to confirm everything is working!
Go ahead and delete all of the files (except additional.css
), from the CSS folder.
Once that’s done, run the build command:
npm run build-css
And there you go! All of your CSS files have been generated with this one command — powerful stuff!
You can use this build on any future projects! #
To set up this build on future projects, you only need to copy the scripts and devDependencies from this project into the package.json
of your new project and run npm install
.
We have now created a build process for our SASS projects! We can compile, merge, prefix and compress our stylesheets with a single command.
Thus, we’ve significantly improved upon our development workflow!
Next up, I’ve included a bonus section on how we can use SASS mixins to better manage our Media Queries.
End of section Quiz!
What does prefixing achieve?
It converts our main SASS file into CSS.
It merges all of our CSS files into one file.
It adds code to help ensure cross-browser compatibility.
It reduces our code size to maximise performance.
Get hands-on with 1300+ tech skills courses.