css-modules-loader-core

A loader-agnostic CSS Modules implementation, based on PostCSS

ISC 18 个版本
安装
npm install css-modules-loader-core
yarn add css-modules-loader-core
pnpm add css-modules-loader-core
bun add css-modules-loader-core
README

CSS Module Loader Core

A loader-agnostic CSS Modules implementation, based on PostCSS

Build Status

API

import Core from 'css-modules-loader-core'
let core = new Core()

core.load( sourceString , sourcePath , pathFetcher ) =>
  Promise({ injectableSource, exportTokens })

Processes the input CSS sourceString, looking for dependencies such as @import or :import. Any localisation will happen by prefixing a sanitised version of sourcePath When dependencies are found, it will ask the pathFetcher for each dependency, resolve & inline any imports, and return the following object:

  • injectableSource: the final, merged CSS file without @import or :import statements
  • exportTokens: the mapping from local name to scoped name, as described in the file's :export block

These should map nicely to what your build-tool-specific loader needs to do its job.

new Core([plugins])

The default set of plugins is [postcss-modules-local-by-default, postcss-modules-extract-imports, postcss-modules-scope] (i.e. the CSS Modules specification). This can override which PostCSS plugins you wish to execute, e.g.

import Core from 'css-loader-core'
import autoprefixer from 'autoprefixer'
import colorFunctions from 'postcss-color-function'

// Don't run local-by-default, but use colorFunctions 
// beforehand and autoprefixer afterwards:
let core = new Core([
  colorFunctions, 
  core.plugins.extractImports, 
  core.plugins.scope, 
  autoprefixer("Last 2 Versions")
])
版本列表
1.1.0 2017-05-22
1.0.1 2016-08-19
1.0.0 2015-10-21
1.0.0-beta4 2015-09-22
1.0.0-beta3 2015-09-22
1.0.0-beta2 2015-09-22
0.0.12 2015-08-04
0.0.11 2015-07-02
0.0.10 2015-06-18
0.0.9 2015-06-14
0.0.8 2015-06-11
0.0.7 2015-06-09
0.0.6 2015-06-07
0.0.5 2015-06-04
0.0.4 2015-06-04
0.0.3 2015-06-01
0.0.2 2015-06-01
0.0.1 2015-06-01