1.0.1 • Published 6 years ago

compile-string-loader v1.0.1

Weekly downloads
3
License
MIT
Repository
github
Last release
6 years ago

compile-string-loader

Build Status

compile-string-loader module for Webpack.

Usage

Compile and expose a string. Very handy for CSS in JS.

Getting Started

To begin, you'll need to install compile-string-loader:

$ yarn add compile-string-loader --dev

Inline

// App.js
import styles from 'style-loader!css-loader!compile-string-loader!babel-loader!./app.css.js';

Config

// webpack.config.js
{
  module: {
    rules: [
      {
        test: /\.css\.js$/,
        use: [
          'style-loader',
          {
            loader: 'css-loader',
            options: {
              modules: true,
            }
          },
          'compile-string-loader',
          'babel-loader'
        ]
      }
    ]
  }
}

Example

// colors.js
export const red = '#ff0000';
export const white = '#ffffff';
// app.css.js
import * as colors from './colors';

export default `
  .myElement {
    background-color: ${colors.white};
    color: ${colors.red};
    width: 100%;
  }
`;
// App.js
import { myElement } from './app.css.js';

const container = document.getElementById('container');

container.classList.add(myElement);
// webpack.config.js
{
  module: {
    rules: [
      {
        test: /\.css\.js$/,
        use: [
          'style-loader',
          {
            loader: 'css-loader',
            options: {
              modules: true,
            }
          },
          'compile-string-loader',
          'babel-loader'
        ]
      }
    ]
  }
}

Miscellaneous

compile-string-loader remains a loader. So if you were to write postcss, you might just wanna add a postcss-loader accordingly.

// app.css.js
import * as colors from './colors';

// using postcss-nested
export default `
  .myElement {
    background-color: ${colors.white};
    color: ${colors.red};
    width: 100%;
    
    div {
      width: 50%;
    }
  }
`;
// webpack.config.js
{
  module: {
    rules: [
      {
        test: /\.css\.js$/,
        use: [
          'style-loader',
          {
            loader: 'css-loader',
            options: {
              modules: true,
            }
          },
          'postcss-loader',
          'compile-string-loader',
          'babel-loader'
        ]
      }
    ]
  }
}

License

MIT