How to use global variables in CSS-Modules?

前端 未结 4 2165
猫巷女王i
猫巷女王i 2021-02-13 13:24

I\'m busy learning React with CSS-Modules and I don\'t quite understand how one would store variables? For example, in Sass you\'re able to do this:

// _variable         


        
相关标签:
4条回答
  • 2021-02-13 13:39

    You may use sass preprocessor and sass-resources-loader.

    sass-resources-loader will add all your variables, mixins, etc into each required sass file.

    0 讨论(0)
  • 2021-02-13 13:42

    Check this out

    //vars.css
    :root {
      --color-black: #222;
    }
    
    
    //myComponent.module.css
    @import './vars.css';
    
    .component{
      color: var(--color-black);
    }
    
    0 讨论(0)
  • 2021-02-13 13:49

    One way could be to use dependencies. For example,

    // variables.css
    .primaryColor {
      color: #f1f1f1
    }
    
    // heading.css
    .heading {
      composes: primaryColor from "./variables.css"
    }
    

    See more detailed information here: https://github.com/css-modules/css-modules#dependencies

    If you're using webpack there are more examples here: https://github.com/webpack/css-loader#composing-css-classes

    Also if you are using webpack you can still use Sass with CSS modules.

    0 讨论(0)
  • 2021-02-13 13:53

    The CSS-Modules documentation mentions variables here: https://github.com/css-modules/css-modules/blob/master/docs/values-variables.md

    With this you can import variables as so:

    @value colors: "../../main/colors.css";
    @value primary, secondary, tertiary from colors;
    

    which can be used in your css:

    .main {
        background-color: tertiary;
        border-top: 30px solid primary;
    }
    

    To make this work postcss-loader and postcss-modules-values need to be added to your webpack config. See below:

            {
                test: /\.css$/,
                use: [{
                        loader: 'style-loader'
                    },
                    {
                        loader: 'css-loader',
                        options: {
                            modules: true,
                            localIdentName: '[name]_[local]_[hash:base64:5]'
                        }
                    },
                    {
                        loader: 'postcss-loader',
                        options: {
                            plugins: [postcssModulesValues]
                        }
                    }
                ]
            }
    
    0 讨论(0)
提交回复
热议问题