在vue中使用css modules替代scroped的方法


Posted in Javascript onMarch 10, 2018

前面的话

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
    }
   }
  }
 ]
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 四则运算精度修正函数代码
May 31 Javascript
js统计录入文本框中字符的个数并加以限制不超过多少
May 23 Javascript
浅谈javascript中的DOM方法
Jul 16 Javascript
jQuery+CSS实现的网页二级下滑菜单效果
Aug 25 Javascript
jQuery实现的分子运动小球碰撞效果
Jan 27 Javascript
jQuery实现图片向左向右切换效果的简单实例
May 18 Javascript
ECMAScript6快速入手攻略
Jul 18 Javascript
jQuery模拟淘宝购物车功能
Feb 27 Javascript
Vue渲染函数详解
Sep 15 Javascript
angular5 httpclient的示例实战
Mar 12 Javascript
javascript设计模式 ? 解释器模式原理与用法实例分析
Apr 17 Javascript
vue+iview实现文件上传
Nov 17 Vue.js
redux-saga 初识和使用
Mar 10 #Javascript
JS获取input[file]的值并显示在页面的实现方法
Mar 09 #Javascript
vue获取当前点击的元素并传值的实例
Mar 09 #Javascript
vue.js获得当前元素的文字信息方法
Mar 09 #Javascript
vue element-ui 绑定@keyup事件无效的解决方法
Mar 09 #Javascript
jquery点击回车键实现登录效果并默认焦点的方法
Mar 09 #jQuery
在vue里面设置全局变量或数据的方法
Mar 09 #Javascript
You might like
PHP批量采集下载美女图片的实现代码
2013/06/03 PHP
PHP编程风格规范分享
2014/01/15 PHP
php中HTTP_REFERER函数用法实例
2014/11/21 PHP
php实现过滤UBB代码的类
2015/03/12 PHP
php上传图片客户端和服务器端实现方法
2015/03/30 PHP
PHP异常处理Exception类
2015/12/11 PHP
Thinkphp5行为使用方法汇总
2017/12/21 PHP
PHP+MySQL高并发加锁事务处理问题解决方法
2018/04/30 PHP
让你的博客飘雪花超出屏幕依然看得见
2013/01/04 Javascript
js兼容火狐显示上传图片预览效果的方法
2015/05/21 Javascript
Javascript实现的Map集合工具类完整实例
2015/07/31 Javascript
js实现显示当前状态的导航效果代码
2015/08/28 Javascript
修改Jquery Dialog 位置的实现方法
2016/08/26 Javascript
[原创]JavaScript语法高亮插件highlight.js用法详解【附highlight.js本站下载】
2016/11/01 Javascript
使用BootStrap实现表格隔行变色及hover变色并在需要时出现滚动条
2017/01/04 Javascript
JS鼠标3次点击事件实现代码及扩展思路
2017/09/12 Javascript
使用js实现将后台传入的json数据放在前台显示
2018/08/06 Javascript
基于vue.js中关于下拉框的值默认及绑定问题
2018/08/22 Javascript
使用vue.js在页面内组件监听scroll事件的方法
2018/09/11 Javascript
jQuery+ajax实现批量删除功能完整示例
2019/06/06 jQuery
KnockoutJS数组比较算法实例详解
2019/11/25 Javascript
nuxt.js服务端渲染中axios和proxy代理的配置操作
2020/11/06 Javascript
Python实现保证只能运行一个脚本实例
2015/06/24 Python
Python字符编码判断方法分析
2016/07/01 Python
Python 列表理解及使用方法
2017/10/27 Python
Python实现发送与接收邮件的方法详解
2018/03/28 Python
Python字符串中添加、插入特定字符的方法
2019/09/10 Python
详解Python3定时器任务代码
2019/09/23 Python
团日活动总结
2014/04/28 职场文书
健康状况证明模板
2014/10/23 职场文书
会计主管岗位职责
2015/04/02 职场文书
党支部培养考察意见
2015/06/02 职场文书
2016年119消防宣传日活动总结
2016/04/05 职场文书
golang实现一个简单的websocket聊天室功能
2021/10/05 Golang
Python Pygame实战之塔防游戏的实现
2022/03/17 Python
教你使用RustDesk 搭建一个自己的远程桌面中继服务器
2022/08/14 Servers