/nodetocss-loader

injected node variable in sass/less as a sass/less global variable

Primary LanguageJavaScript

Loads a js file and injected variable in sass/less/stylus

Install

npm install nodetocss-loader --save-dev

Features

varivables less sass stylus
string
List x
Map x

Basic Usage

//./build/scss-env.js
'use strict';
const [,,lang] = process.argv
module.exports = {
  'bk':'red',
  "h":{
    "h1": "20px",
    "h2": "30px",
    "h3": "40px",
  },
  "list":['green','blue']
  ...
};
// webpack.config.js
module.exports = {
	...
    module: {
        rules: [{
            test: /\.scss$/,
            use: [
                "style-loader", // creates style nodes from JS strings
                "css-loader", // translates CSS into CommonJS
                "sass-loader", // compiles Sass to CSS, using Node Sass by default
                {
                  loader: 'nodetocss-loader',
                  options: {
                    // Provide path to the file with resources
                    path: './build/scss-env.js'
                  }
                }
            ]
        }]
    }
};

The default precompiler language is sass, if you use less or stylus, you use add 'lang' attributes,just like :

 options: {
   // Provide path to the file with resources
   path: './build/scss-env.js',
   lang: 'less'
  }

extend

if will have ohters css precompiler,you can rewrite the function ,just do :

 options: {
   // Provide path to the file with resources
   path: './build/scss-env.js',
   rewrite:(lang,key,value){
      switch(lang){
        case 'sass' : return '$'+ key + ":" + value + ";\n";;break;
        case 'less' : return '@'+ key + ":" + value + ";\n";;break;
        case 'stylus' : return  key + "=" + value + ";\n";;break;
        default: break;
      }
    }
  }

Reference

https://github.com/EdwardIrby/jsontosass-loader

Finally

please give me a star 😊