详解.vue文件中style标签的几个标识符


Posted in Javascript onJuly 17, 2018

.vue文件中style标签的几个标识符

在人生就要绝望的时候, 被编辑器所提示的一个scopedSlots所拯救.

卧槽, 写到最后才发现这个属性的具体卵用. 详情见最后解决办法.

问题背景

问题由来

  • 项目中使用了elementUI框架, 与.vue文件.
  • 现状: <template>中使用$style:[类名], <style module>进行了样式的绑定.
  • 个人认为使用$style这种方式的绑定, 写起来很麻烦.
  • 不仅仅是麻烦更重要的是, 没有办法直接影响和修改element中的样式.
<template>
 <span :class="$style.text">
  ...
 </span>
</template>
<style module>
 .text {}
</style>

陷入点

  • 不知道清楚再style中使用了module这个属性的具体含义
  • dev启动环境下, 使用scoped形成独立作用域后, 并不能影响到elemnt中组件的样式.
  • 使用scopedSlots标识style标签后, 解决问题. 但出现 dev环境正常, 部署后, 不起作用

问题详解

认识.vue<style>标签

这应该是关系到, vue-loader这个webpack的插件
  • vue-laoder会解析组件, 提取语言块. 在需要的时候, 经过其他的loader处理, 最后组装成一个commonjs模块.
    • 其实就是export default出来一个对象 然后呢, 上面的<template>, 挂载在 这个对象的template属性上
    • 之前, 直接import引近来一些样式文件也是可行的, 但当时并未思考这些标识如何实现.
  • <style>可以有module和scoped属性, 来将样式封装到组件中. 具有不同封装模式的多个<style>标签, 可以在一个组件中混合使用
  • 默认情况下, style-loader会提取内容, 并通过<style>标签, 加入到文档的<head>中. 也可以通过配置webpack形成单个.css文件.

$style配合<module>如何工作

参考: https://vue-loader-v14.vuejs.org/zh-cn/features/css-modules.html

<style>中使用一个module属性, 可以形成名为$style的计算属性从而在节点中动态绑定样式.

<span :class="$style.text">
 ...
</span>

形成的计算属性可以绑定:class的object/array语法.

  • 在html中 class绑定的事一个object语法.
  • 如果在data上面的isRed这个属性是true的话, 就会添加上red这个属性名
  • 从而形成了一个属性控制
<span :class="{[$style.red] : isRed}">
 测试
</span>
<script>
 data() {
  return {
   entries: [],
   isRed: true,
  };
 },
</script>
<style module>
 .red {
  color: red;
 }
</style>
  • 可以在js中通过console.log(this.$style.red)进行访问
  • 可以使用module=''来更改$style这个名称
<div :class="aaa.root">
</div>
<style lang="less" module="aaa">
</style>

scoped的作用域是如何的

<style></style>标签有scoped属性的时候, 他的css样式只作用在当前作用域

使用了scoped之后, 父组件的样式不会再深入到自组件.

  • 不过子组件的根节点同时受到 父组件有作用域的CSS 和 子组件有作用域的影响
  • 但是有一点: 如果我们在子组件上面添加了一个类样式 就能向下一层层的进行修改

深度作用选择器: >>> 或者是 /deep/

  • 已验证: 在less下面不起作用
  • 已验证: 在普通的css下才起作用.
  • 据网上说, stylus起作用, scss不起作用, 并未验证

v-html动态生成的样式不受作用域内样式影响, 但我想应该加个类样式名称,可以解决.(未验证)

css的作用域的渲染方式, 远不如class的渲染速度

递归组件中, 小心使用CSS样式.

element中样式的混入方式 (todo)

  • 通过打包进行样式的使用, 故使用方式在build的文件夹中
  • 样式目录为: element/packages/theme-chalk/src/menu.scss, 以方便后期的具体查看

解决过程

使用scopedSlots解决

我擦哦, 再次测试后, 发现添加scopedSlots并没有什么卵用, 和什么都不写是他妈一个样子啊.. 我说怎么, 怎么查了半天, 也没人用.
还被这玩意所拯救, 也真是够了..
当时还骄傲了半天, 还以为是发现了新天地, 也真是6了.

添加scoped之后, 在子组件上面添加类样式名, 发现并没有卵用

错误依旧: 只是在表面层上的有一些data-v的注入

详解.vue文件中style标签的几个标识符

没有找到需要注入到里面的条件, 发现自己前面大部分的判断都是错误的.

解决方案一:scoped方案

  • 将无法进行样式覆盖的部分拿出来
  • 使用原生的css样式, 添加scoped
  • 使用 >>> 语法糖进行样式的注入
<style scoped>

.main_nav .el-menu .el-submenu >>> .el-submenu__title {
 background-color: red;
}
</style>

解决方案二: module方案

  • 使用module进行属性的选择
  • 然后是用:global()进行这个属性下面的全部选择
  • 进而选中这个没有在作用域下面但是可以选择到的元素
  • 个人始终认为这种选择方案, 可以做到css作用域的区分, 但是, 并不灵活
  • 具体的以后再分析
<style lang="less" module="aaa">
.red {
 .item {
  :global(.el-submenu__title) {
   background: red;
  }
 }
}
</style>

详解.vue文件中style标签的几个标识符

总结

  • .vue文件中的<style></style>只有modulescoped, 没有其他取巧方案
  • module形成一个代表属性的计算属性, 默认名称为$style, 其中的:global()可以进行这个区域下面的所有元素的选择.
  • scoped形成的作用域, 可以通过>>>来进行子组件的样式覆盖, 带只要原生的css支持.

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

Javascript 相关文章推荐
IE与FireFox的兼容性问题分析
Apr 22 Javascript
DOM_window对象属性之--clipboardData对象操作代码
Feb 03 Javascript
JavaScript 高级篇之函数 (四)
Apr 07 Javascript
JQuery实现动态表格点击按钮表格增加一行
Aug 24 Javascript
20个实用的JavaScript技巧分享
Nov 28 Javascript
js实现点击添加一个input节点
Dec 05 Javascript
对jquery的ajax进行二次封装以及ajax缓存代理组件:AjaxCache详解
Apr 11 Javascript
原生js实现水平方向无缝滚动
Jan 10 Javascript
AngularJS实现的根据数量与单价计算总价功能示例
Dec 26 Javascript
小程序实现展开/收起的效果示例
Sep 22 Javascript
element-ui表格合并span-method的实现方法
May 21 Javascript
在vs code 中如何创建一个自己的 Vue 模板代码
Nov 10 Javascript
webstrom Debug 调试vue项目的方法步骤
Jul 17 #Javascript
vue实现未登录跳转到登录页面的方法
Jul 17 #Javascript
打通前后端构建一个Vue+Express的开发环境
Jul 17 #Javascript
详解如何从零开始搭建Express+Vue开发环境
Jul 17 #Javascript
微信小程序自定义组件之可清除的input组件
Jul 17 #Javascript
微信小程序倒计时功能实例代码
Jul 17 #Javascript
详解vue+webpack+express中间件接口使用
Jul 17 #Javascript
You might like
PL-880隐藏功能
2021/03/01 无线电
php制作unicode解码工具(unicode编码转换器)代码分享
2013/12/24 PHP
php简单创建zip压缩文件的方法
2016/04/30 PHP
PHP实现一个简单url路由功能实例
2016/11/05 PHP
jQuery调用WebService的实现代码
2011/06/19 Javascript
jQuery动态添加与删除tr行实例代码
2016/10/18 Javascript
jQuery Easyui datagrid连续发送两次请求问题
2016/12/13 Javascript
JS常见简单正则表达式验证功能小结【手机,地址,企业税号,金额,身份证等】
2017/01/22 Javascript
jquery封装插件时匿名函数形参和实参的写法解释
2017/02/14 Javascript
微信小程序动态的加载数据实例代码
2017/04/14 Javascript
vue 的keep-alive缓存功能的实现
2018/03/22 Javascript
Iview Table组件中各种组件扩展的使用
2018/10/20 Javascript
详解nuxt路由鉴权(express模板)
2018/11/21 Javascript
解决layer.open弹出框不能获取input框的值为空的问题
2019/09/10 Javascript
JS实现iframe中子父页面跨域通讯的方法分析
2020/03/10 Javascript
微信公众号中的JSSDK接入及invalid signature等常见错误问题分析(全面解析)
2020/04/11 Javascript
[01:00:14]DOTA2官方TI8总决赛纪录片 真视界True Sight
2019/01/16 DOTA
[46:12]完美世界DOTA2联赛循环赛 DM vs Matador BO2第一场 11.04
2020/11/04 DOTA
使用python提取html文件中的特定数据的实现代码
2013/03/24 Python
老生常谈进程线程协程那些事儿
2017/07/24 Python
疯狂上涨的Python 开发者应从2.x还是3.x着手?
2017/11/16 Python
Python+OpenCV实现车牌字符分割和识别
2018/03/31 Python
python numpy和list查询其中某个数的个数及定位方法
2018/06/27 Python
python TKinter获取文本框内容的方法
2018/10/11 Python
django+mysql的使用示例
2018/11/23 Python
python脚本开机自启的实现方法
2019/06/28 Python
wxpython绘制圆角窗体
2019/11/18 Python
解决Jupyter Notebook使用parser.parse_args出现错误问题
2020/04/20 Python
Python-opencv实现红绿两色识别操作
2020/06/04 Python
python爬虫请求头的使用
2020/12/01 Python
选购世界上最好的美妆品:Cult Beauty
2017/11/03 全球购物
英国门销售网站:Green Tree Doors
2020/01/07 全球购物
异常和异常类的概念
2014/09/12 面试题
简述Linux文件系统通过i节点把文件的逻辑结构和物理结构转换的工作过程
2012/04/17 面试题
2014年妇幼保健工作总结
2014/12/08 职场文书
获奖感言一句话
2015/07/31 职场文书