Loads a js file and injected variable in sass/less/stylus
npm install nodetocss-loader --save-dev
varivables | less | sass | stylus |
---|---|---|---|
string | √ | √ | √ |
List | √ | √ | x |
Map | √ | √ | x |
//./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'
}
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;
}
}
}
https://github.com/EdwardIrby/jsontosass-loader
please give me a star 😊