美文网首页
CSS Modules

CSS Modules

作者: 坤嬷嬷 | 来源:发表于2018-09-13 18:07 被阅读52次


    CSS Modules

    CSS Modules 是一个流行的,用于模块化和组合 CSS 的系统。vue-loader 提供了与 CSS Modules 的一流集成,可以作为模拟 scoped CSS 的替代方案。

    #用法

    首先,CSS Modules 必须通过向 css-loader 传入 modules: true 来开启:

    // webpack.config.js{module:{rules:[// ... 其它规则省略{test:/\.css$/,use:['vue-style-loader',{loader:'css-loader',options:{// 开启 CSS Modulesmodules:true,// 自定义生成的类名localIdentName:'[local]_[hash:base64:8]'}}]}]}}

    然后在你的 <style> 上添加 module 特性:

    <style module>

    .red{color:red;}

    .bold{font-weight:bold;}

    </style>

    这个 module 特性指引 Vue Loader 作为名为 $style 的计算属性,向组件注入 CSS Modules 局部对象。然后你就可以在模板中通过一个动态类绑定来使用它了:

    <template><p :class="$style.red">This should be red</p></template>

    因为这是一个计算属性,所以它也支持 :class 的对象/数组语法:

    <template><div><p:class="{ [$style.red]: isRed }">Am I red?</p><p:class="[$style.red, $style.bold]">Red and bold</p></div></template>

    你也可以通过 JavaScript 访问到它:

    <script>exportdefault{created(){console.log(this.$style.red)// -> "red_1VyoJ-uZ"// 一个基于文件名和类名生成的标识符}}</script>

    你可以查阅 CSS Modules 规范了解更多细节,诸如 global exceptions 和 composition 等。

    #可选用法

    如果你只想在某些 Vue 组件中使用 CSS Modules,你可以使用 oneOf 规则并在 resourceQuery 字符串中检查 module 字符串:

    // webpack.config.js -> module.rules{test:/\.css$/,oneOf:[// 这里匹配 `<style module>`{resourceQuery:/module/,use:['vue-style-loader',{loader:'css-loader',options:{modules:true,localIdentName:'[local]_[hash:base64:5]'}}]},// 这里匹配普通的 `<style>` 或 `<style scoped>`{use:['vue-style-loader','css-loader']}]}

    #和预处理器配合使用

    CSS Modules 可以与其它预处理器一起使用:

    // webpack.config.js -> module.rules{test:/\.scss$/,use:['vue-style-loader',{loader:'css-loader',options:{modules:true}},'sass-loader']}

    #自定义的注入名称

    在 .vue 中你可以定义不止一个 <style>,为了避免被覆盖,你可以通过设置 module 属性来为它们定义注入后计算属性的名称。

    <style module="a">/* 注入标识符 a */</style>

    <style module="b">/* 注入标识符 b */</style>

    相关文章

      网友评论

          本文标题:CSS Modules

          本文链接:https://www.haomeiwen.com/subject/rflggftx.html