在vue中使用css modules替代scroped

前面的话

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

引入

  最开始使用Vue的时候,提倡并大量使用的是scoped这种技术

<style scoped>
  @media (min-width: 250px) {
    .list-container:hover {
      background: orange;
    }
  }
</style>

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

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

<span data-v-0467f817 class="errShow">用户名不得为空</span>

  以上面的代码为例,使用scoped之后,它在元素上添加了一个唯一的属性‘data-v-0467f817‘,CSS样式被编译如下

.errShow[data-v-0467f817] {
    font-size: 12px;
    color: red;
}

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

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

<span class="_3ylglHI_7ASkYw5BlOlYIv_0">用户名不得为空</span>

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

模块化

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

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

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

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

  1、命名约定类

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

  2、CSS in JS

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

  3、使用JS来管理样式

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

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

写法

  下面来介绍CSS modules的写法

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

<style module>
.red {color: red;}</style>

  在模板中使用动态类绑定:class,并在类名前面加上‘$style.‘

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

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

<h4 :class="$style[‘header-tit‘]">类别推荐</h4>

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

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

  更复杂的对象语法

    <ul     :class="{
        [$style.panelBox]:true,
        [$style.transitionByPanelBox]:needTransition
      }"

  更复杂的数组语法

    <li
      :class="[
        $style[‘aside-item‘],
        {[$style[‘aside-item_active‘]]:(i === index)}
      ]"

配置

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

{
  modules: true,
  importLoaders: 1,
  localIdentName: ‘[hash:base64]‘
}

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

module: {
  rules: [
    {
      test: ‘\.vue$‘,
      loader: ‘vue-loader‘,
      options: {
        cssModules: {
          localIdentName: ‘[path][name]---[local]---[hash:base64:5]‘,
          camelCase: true
        }
      }
    }
  ]
}

原文地址:https://www.cnblogs.com/xiaohuochai/p/8537959.html

时间: 2024-07-28 13:04:00

在vue中使用css modules替代scroped的相关文章

在Angular1.X中使用CSS Modules

在Angular1.5中,增加了一个Component方法,并且定义了组件的若干生命周期hook,在代码规范中也是推崇组件化开发,但是很遗憾的是,CSS模块化组件化的问题并没有得到解决,大部分项目的打包方式还是将所有CSS打包成一个完整的CSS文件,然后插入到html中,这样做的坏处显而易见,如果团队没有良好的CSS代码规范,很容易引起CSS的冲突,本文使用CSS Modules来解决Angular1.X中存在的CSS 冲突问题. 为了便于读者查看并动手操作,我将所有的代码打包成了一个库,首先在

vue中使用css全局样式

在stylus中使用: 1.在src目录下的assets文件中的styles文件中创建一个varibles.styl文件 2.在varibles.styl文件中书写代码 $bgColor = #00bcd4 3.在vue组件的style中引入全局样式 @import '../../../assets/styles/varibles.styl' 4.使用全局样式 .header{ background : $bgColor }  原生css中使用: 1.在src目录下的assets文件中的styl

vue中引入css文件

两种方式引入css文件,一种是直接在main.js中引入,即下面这种写法: import 'element-ui/lib/theme-default/index.css' 这种写法适用于此css文件存在于项目中,不适用于通过网址访问的方式引入,会报错.偶试着引入Font Awesome,结果报错: import "http://netdna.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" 而直接在组件中引入却可

vue中的半程动画

vue中使用css和第三方库完成的动画都是全程动画(又开始,有结束),当有些需求只需要又开始的动画,不需要有结束的动画时(加入购物车时,有一个小球慧聪商品按钮区域,运动到购物车图标上,并不会返回回去),他们两个不会满足需求 此时vue为我们提供了 JavaScript 钩子可以满足需求 <transition v-on:before-enter="beforeEnter" v-on:enter="enter" v-on:after-enter="af

CSS modules 与 React中实践

最近一直在学习React,看上去蛮简单的内容,其实学习曲线还是比较高的. 目前学到css绑定的问题,看到有一篇好的文章,就转过来了. CSS 模块化的解决方案有很多,但主要有两类.一类是彻底抛弃 CSS,使用 JS 或 JSON 来写样式.Radium, jsxstyle ,react-style 属于这一类.优点是能给 CSS 提供 JS 同样强大的模块化能力:缺点是不能利用成熟的 CSS 预处理器(或后处理器) Sass/Less/PostCSS, :hover 和 :active 伪类处理

Vue中引入bootstrap导致的CSS问题

最近在进行vue.js+webpack进行模块化开发的时候,遇到一个奇怪的问题. 问题是这样的: 1. 在main.js文件中引入bootstrap的js和css. 2. 自己写了一个Header.vue模块,其中的导航条使用的bootstrap的class和自己的class. <ul class="navbar-nav my-navBar" id="my-navBar"> 3. 在Header.vue中定义了一些ul li 和 a 标签的样式. ul.

[Vue]Scoped Css与Css Modules的区别

均为解决CSS全局作用域问题(样式冲突(污染))的一个解决方案. 1.Scoped CSS 当 <style> 标签有 scoped 属性时,相当于在元素中添加了一个唯一属性用来区分. <style scoped> .example { color: red; } </style> <template> <div class="example">hi</div> </template> 它通过使用 Po

在Vue中使用 animate.css 库

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>在Vue中使用 animate.css 库</title> <script src="./vue.js"></script> <link rel="stylesheet" type=&qu

vue 中 scoped的用法 以及css文件引入问题的补充

自:https://blog.csdn.net/weixin_39941429/article/details/80254724 下面再说说VUE中scoped的编译原理吧.具体可以参考vue-loader 所谓的局部css,就是通过vue-loader这个插件,在编译打包的时候将带有scoped属性的css打上一个tag,同时将template内的所有html都打上一个相同的tag,最后通过css的属性选择器定位,造就了所谓的局部css.参考scoped内复写组件样式 css-loader对i