What ?

css 的作用域表现。

Css modules

是一个CSS文件,其中所有类名和动画名称默认为局部作用域。
使用JS编译原生的CSS文件,使其具备模块化的能力,该文件需要import使用。

Scoped

在vue文件中的style标签上,有一个特殊的属性:scoped。
此样式仅适用于当前组件元素,从而使组件之间的样式不互相污染。

How ?

Css modules

实现原理

通过给样式名加hash字符串后缀的方式,实现特定作用域语境中的样式编译后的样式在全局唯一。

具体效果demo

// webpack.config.js
{
test: /\.css$/,
loader: 'style!css-loader?modules&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]'
}
编译前 - vue 环境
<template>
<div :class="$style.green">demo demo</div>
</template> <style module>
.green {
color: green;
}
</style> 编译后 - vue 环境
<div class="green_3UI7s9iz">demo demo</div> .green_3UI7s9iz {
color: green;
}

由此可见

  1. css module直接替换了类名,排除了用户设置类名影响组件样式的可能性。优点就是不必再担心命名约定。
  2. $style.green 是个变量,即可在js中引用,引用方式为:this.$style.green。
  3. modules 即为启用,localIdentName 是设置生成样式的命名规则。

应用场景

只应用于某个组件,其他组件不适用。

⚠️ 注意点

  • 在处理动画animation的关键帧keyframes,动画名称必须先写:

    • 比如,animation: deni .5s,能正常编译; animation: .5s deni, 则编译异常
  • css modules生效方式:
    • 需要css-loader配置才能生效。
    • 若使用的是style-loader,则需配置更换为vue-style-loader才可生效。

css modules如何解决权重问题?

允许通过重命名或命名空间来封装样式规则,减少对选择器的约束,从而达到不需要特定方法就可舒服的使用类名。

当样式规则耦合到每个组件时,当不再使用组件时,样式也会被移除。

Scoped

实现原理

vue通过在DOM结构以及css样式上加唯一不重复的标记,以保证唯一,达到样式私有化模块化的目的。

具体效果demo

// 编译前 demo.vue
<template>
<div class="demo-c">hello world!</div>
</template> <style lang="less" scoped>
.demo-c {
width: 100%;
height: 100px;
background-color: green;
color: #fff;
}
</style>
// 编译后-dom
<div data-v-48baf84c="" class="demo-c">hello world!</div>
// 编译后-css
.demo-c[data-v-48baf84c] {
width: 100%;
height: 1.333333rem;
background-color: green;
color: #fff;
}

应用场景

scoped css可以直接在能跑起来的vue项目中使用,且对应的样式只对该组件有效,不被其他组件污染。

⚠️ 注意点

“权重加重”的意思: 如果我们要去修改这个样式,需要更高的权重去覆盖其样式。

  • 由于css样式优先级的特性,scoped处理会造成每个样式的权重加重了。
  • 若组件内部包含有子组件,只会给子组件的最外层标签加上当前组件的data属性:
    • 一般父组件如果加了scoped,会比已设置过自己样式的子组件内除最外层标签的内层标签的权重低,所以不会影响他们的样式。
  • scoped会使标签选择器渲染变慢更多倍。
  • 若用户再定义了相同的类名,也有可能会影响到组件的样式。
  • 具有scoped属性的样式只会应用到当前元素和其子元素。Inline样式仍然比scoped样式优先级高,所以,最好避免使用inline样式。

Why ?

目的

  • css 模块化
  • css 私有化:不被污染
  • css 复用性
  • 解决CSS中的全局作用域问题

总结

实现同一目的,比较它们的优缺点,css modules 配置并不麻烦且实现的整体效果更优于scoped css,在此个人更推荐使用css modules。

参考资料

CSS Modules 与 scoped 的不一样的更多相关文章

  1. [Vue]Scoped Css与Css Modules的区别

    均为解决CSS全局作用域问题(样式冲突(污染))的一个解决方案. 1.Scoped CSS 当 <style> 标签有 scoped 属性时,相当于在元素中添加了一个唯一属性用来区分. & ...

  2. vue中scoped vs css modules

    注意:此文是默认你已经具备scoped和css modules的相关基础知识,所以不做用法上的讲解. 在vue中,我们有两种方式可以定义css作用域,一种是scoped,另一种就是css module ...

  3. 在Angular1.X中使用CSS Modules

    在Angular1.5中,增加了一个Component方法,并且定义了组件的若干生命周期hook,在代码规范中也是推崇组件化开发,但是很遗憾的是,CSS模块化组件化的问题并没有得到解决,大部分项目的打 ...

  4. 在vue中使用css modules替代scroped

    前面的话 css modules是一种流行的模块化和组合CSS的系统. vue-loader提供了与css modules的集成,作为scope CSS的替代方案.本文将详细介绍css modules ...

  5. CSS Modules入门教程

    为什么引入CSS Modules 或者可以这么说,CSS Modules为我们解决了什么痛点.针对以往我写网页样式的经验,具体来说可以归纳为以下几点: 全局样式冲突 过程是这样的:你现在有两个模块,分 ...

  6. CSS modules 与 React中实践

    最近一直在学习React,看上去蛮简单的内容,其实学习曲线还是比较高的. 目前学到css绑定的问题,看到有一篇好的文章,就转过来了. CSS 模块化的解决方案有很多,但主要有两类.一类是彻底抛弃 CS ...

  7. 在React中使用CSS Modules设置样式

    最近,一直在看React...那真的是一个一直在学的过程啊,从配置环境webpack,到基础知识jsx,babel,es6,没有一个不是之前没有接触的.其实,我内心是兴奋的啊,毕竟,活着就是要接触一些 ...

  8. Webpack 2 视频教程 012 - 理解Webpack 中的 CSS 作用域与 CSS Modules

    原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...

  9. css模块化及CSS Modules使用详解

    什么是css模块化? 为了理解css模块化思想,我们首先了解下,什么是模块化,在百度百科上的解释是,在系统的结构中,模块是可组合.分解和更换的单元.模块化是一种处理复杂系统分解成为更好的可管理模块的方 ...

随机推荐

  1. 安卓adb工具的安装方法

    adb是Android的一个很重要的调试工具,熟练掌握后可实现很多功能,比如有些手机的解锁.ROOT就会用到adb工具.可很多朋友都说不会安装,今天就从最开始的安装方法说起. adb工具其实不用安装, ...

  2. docker常用操作备忘

    一.docker安装 参考资料:阿里云镜像加速1. 安装/升级Docker客户端 curl -fsSL https://get.docker.com | bash -s docker --mirror ...

  3. 跟踪SQL

    在数据库中,找到以下页面,并选择事件中的Tsql下的bath...与stm...

  4. 【ElasticSearch】 elasticsearch-head插件安装

    本章介绍elasticsearch-head插件安装,elasticsearch安装参考:[ElasticSearch] 安装 elasticsearch-head安装和学习可参照官方文档: http ...

  5. MySQL zip版本安装

    一直以来都习惯了使用MySQL安装文件(.exe),今天下载了一个.zip版本的MySQL,安装过程中遇到了一些问题,如下: 1.在MySQL官网上(http://dev.mysql.com/down ...

  6. kvm+webvirtmgr在centos7上的部署

    #!/bin/bash #+++++++++++++++++++++++++++++++++++++++++++++++++++++++安装配置kvm并创建虚拟机+++++++++++++++++++ ...

  7. 导出mysql的表格内容到txt文件

    操作流程: $ mysql -uroot -p mysql> use foo; mysql> select * from userinfo into outfile '/var/lib/m ...

  8. 时序扩展的UML状态图的测试用例生成研究

    一.基本信息 标题:时序扩展的UML状态图的测试用例生成研究 时间:2014 出版源:西南大学 领域分类:时序扩展:UML状态图:测试用例:需求规格说明:模型 二.研究背景 问题定义:时序扩展的UML ...

  9. P层

    package net.goeasyway.uploadimage.presenter; import net.goeasyway.uploadimage.model.Photo;import net ...

  10. jsp获取当前项目跟路径

    在jsp中获取当前项目的根路径: <% String basePath = request.getScheme() + "://"+ request.getServerNam ...