CSS Modules

2018-09-13  本文已影响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>

上一篇 下一篇

猜你喜欢

热点阅读