Sharing Data Between Sass and JavaScript with JSON


For those unable to easily import JSON into their JavaScript enviroment, Andy Matthews has come up with a gist for how to include it using grunt-contrib-concat. Also checkout grunt-json.

Traditionally stylesheets describe the majority of the presentation layer for a website. However as JavaScript becomes necessary to present information in a stylistically consistent way, it becomes troublesome to keep these mediums in sync. Data visualizations and break-point based interaction are prime examples of this; something I bumped into on my most recent project.

I should note that this is not an unsolved problem, and there are many interesting examples of this technique in the wild. However I wanted a simpler solution and I've been wanting to write a Sass plugin anyway.

The result of this curiousity is sass-json-vars</a>. After requiring it, this gem allows JSON files to be included as valid @import paths; converting the top level values into any of the Sass data types (strings, maps, lists).</p> <h2>Usage</h2> <p>Consider the following snippet of JSON (breakpoints shortened for brevity):</p> <pre> {&#10; "colors": {&#10; "red" : "#c33",&#10; "blue" : "#33c"&#10; },&#10;&#10; "breakpoints": {&#10; "landscape" : "only screen and (orientation : landscape)",&#10; "portrait" : "only screen and (orientation : portrait)"&#10; }&#10;}</pre> <p><a href="">sass-json-vars exposes the top level keys as values whenever a JSON file is included using @import.

 @import "variables.json"; &#10;&#10;.element {&#10; color: map-get($colors, red);&#10; width: 75%;&#10;&#10; @media (map-get($breakpoints, portrait) {&#10; width: 100%;&#10; }&#10;}

Similarly, these values can be accessed in JavaScript using a module system such as CommonJS with browserify. For example, if we need to determine if the current browser's orientation is at landscape:

 var breakpoints = require("./variables.json").breakpoints;&#10;&#10;//;var isLandscape = matchMedia(breakpoints.landscape).matches;&#10;&#10;if (isLandscape) {&#10; // do something in landscape mode&#10;}


sass-json-vars</a> can be included similarly to <a href="">sass-globbing</a> or other plugins that add functionality to @import. Simply include it as a dependency in your Gemfile:

 gem &#39;sass-json-vars&#39;

or within Rails:

 group :assets do&#10; gem &#39;sass-json-vars&#39;&#10;end&#10;

Asset paths when using sass-json-vars</a> with the Ruby on Rails asset pipeline should automatically be handled.</p> <h2>Final thoughts</h2> <p><a href="">sass-json-vars supports all of the data types provided by Sass. This could be used to describe media queries for the breakpoint Sass plugin, or store special characters for icons generated by IcoMoon.

Checkout the repo on Github and feel free to comment about how you use it!

Nate is a senior developer in our Durham, NC office, where he focuses on client-side application development. Most days, you can find him neck-deep in JavaScript working with clients such as The Nature Conservancy and the Wildlife Conservation Society.

More posts by Nate
  • Articles
  • Sharing Data Between Sass and JavaScript with JSON