在vue中怎么使用css模块替代”美称

  介绍

这篇文章主要介绍在vue中怎么使用css模块替代”美称,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

<强>引入

最开始使用vue的时候,提倡并大量使用的是作用域这种技术

& lt; style  scoped>   ,@media  (min-width:, 250 px), {   .list-container才能:hover  {   ,,,背景:橙色;   ,,}   ,}   & lt;/style>

这个可选范围属性会自动添加一个唯一的属性(比如data-v-21e5b78)为组件内CSS指定作用域,编译的时候.list-container:悬停会被编译成类似.list-container [data-v-21e5b78]:悬停

但是,它并不能完全避免冲突

& lt; span 数据- v - 0467 f817 类=癳rrShow"在用户名不得为空& lt;/span>

以上面的代码为例,使用作用域之后,它在元素上添加了一个唯一的属性& # 39;数据- v - 0467 f817& # 39;, CSS样式被编译如下

.errShow[数据- v - 0467 f817], {   ,,字体大小:12 px;   ,,颜色:红色;   }

但是,如果用户也定义了一个errShow类名,会影响到所有定义为errShow类名的组件的显示

而CSS模块则做的更彻底,它不是添加属性,而是直接改变类名

& lt; span 类=癬3ylglHI_7ASkYw5BlOlYIv_0"在用户名不得为空& lt;/span>

这样,大大降低了冲突的可能性,只要不是用户直接给跨度标签设置样式,基本上不会影响组件的显示

<强>模块化

CSS模块既不是官方标准,也不是浏览器的特性,而是在构建步骤中对CSS类名选择器限定作用域的一种方式(通过哈希实现类似于命名空间的方法)。类名是动态生成的,唯一的,并准确对应到源文件中的各个类的样式

实际上,CSS模块只是CSS模块化的一种方式。为什么我们需要CSS模块化呢?

CSS的规则都是全局的,任何一个组件的样式规则,都对整个页面有效。于是,亟待解决的就是样式冲突(污染)的问题。一般地,为了解决冲突,会把类命名写长一点,降低冲突几率;加上父元素的选择器,来限制范围等

<强> CSS模块化就是来解决这个问题的,一般地,分为三类

1,命名约定类

该CSS类模块化方案主要用来规范CSS命名,最常见的是本,当然还有允许等,在构建工具出现之前,大多数都是在CSS命名上做文章

2, CSS在JS

彻底抛弃CSS,用javascript来写CSS规则,常见的有styled-components

3,使用JS来管理样式

使用JS编译原生的CSS文件,使其具备模块化的能力,最常见的就是CSS模块

随着构建工具的兴起,越来越多的人开始使用后两者方案,书写CSS时,不用再特意地关心样式冲突问题。只需要使用约定的格式编写代码即可

<强>写法

下面来介绍CSS模块的写法

在风格标签中添加模块属性,表示打开CSS-loader的模块模式

& lt; style  module>   .red {颜色:红色;}& lt;/style>

在模板中使用动态类绑定:类,并在类名前面加上& # 39;美元风格# 39;公司

& lt; template>   ,& lt; p :类=皊tyle.red"美元;比;   却,能够才能should  be 红色   ,& lt;/p>   & lt;/template>

如果类名包含中划线,则使用中括号语法

& lt; h5 :类=懊涝绺?& # 39;header-tit& # 39;]“祝辞类别推荐& lt;/h5>

也可以使用数组或对象语法

,, & lt; p :类=皗,[$ style.red]: isRed }“比;   ,,Am 小姐:红色?   & lt;才能/p>   & lt;才能p :类=癧style.red美元,美元style.bold]“比;   ,,Red 以及大胆   & lt;才能/p>

更复杂的对象语法

,, & lt; ul    ,:类=皗   ,,,(style.panelBox美元):没错,   ,,,($ style.transitionByPanelBox]: needTransition   ,,}“

更复杂的数组语法

, & lt;李   ,,:类=?   ,,,美元风格(& # 39;aside-item& # 39;),   ,,,{[$风格(& # 39;aside-item_active& # 39;]]:(小姐:===,指数)}   ,,)“

<强>配置

css-loader关于CSS模块的默认配置如下

{   ,模块:没错,   ,importLoaders: 1,   ,localIdentName: & # 39;(散列:base64] & # 39;   }

可以使用vue-loader的cssModules选项为css-loader进行自定义的配置

模块:,{   ,规则:[   {才能   ,,,测试:& # 39;\ .vue $ & # 39;   ,,,装载机:& # 39;vue-loader& # 39;   ,,,选择:{   ,,,cssModules:, {   ,,,,localIdentName:, & # 39;(路径)[名字]——(本地)——(散列:base64:5] & # 39;,   ,,,,camelCase:真实   ,,,}   ,,}   ,,}   ,)   }

在vue中怎么使用css模块替代”美称