vue文件中style标签的几个标识符
.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的注入

没有找到需要注入到里面的条件, 发现自己前面大部分的判断都是错误的.
解决方案一: 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></style>只有module和scoped, 没有其他取巧方案 module形成一个代表属性的计算属性, 默认名称为$style, 其中的:global()可以进行这个区域下面的所有元素的选择.scoped形成的作用域, 可以通过>>>来进行子组件的样式覆盖, 带只要原生的css支持.
vue文件中style标签的几个标识符的更多相关文章
- sublime text 3插件改造之AutoFileName去掉.vue文件中img标签后面的width和height,完全去掉!!
		
在.vue文件中img标签使用autofilename提示引入文件时,会在文件后面插入宽度高度,如下图: 文件后面会自动插入height和width,其实这两玩意儿在大多数时候并没卵用,然后就开始了百 ...
 - 防止vue文件中的样式出现‘污染’情况(html5 scoped特性)
		
近期在项目中出现了vue样式污染的情况: 一个页面刚进去时样式不正常,刷新之后,样式才才达到预期那样 在vue中,如果把样式写在vue文件的 style中,可能会出现样式污染的情况,这是要把写样式的标 ...
 - webstorm中es6语法报错,.vue文件中es6语法报错
		
1.webstorm中es6语法报错,解决方法: 打开 Settings => Languages & Frameworks => Javascript把 Javascript L ...
 - Vue 去脚手架插件,自动加载vue文件,style怎么办
		
书接上上会,因为当时也没想好怎么办,所以装聋作哑的忽略了Vue文件中的Style,Vue的做法我看着晕乎乎的,细想的话,无非就是自动填写到dom中,所担心的无非是命名冲突. 在一个项目中(像我这种自娱 ...
 - visual studio 2019不能在vue文件中直接识别less语法
		
试了好多方法,不象vs code那样能直接在template vue文件中就识别less语法下边这种分离的方式是可以的,在项目中也比较实用,将来你代码量大了,样式/脚本也还是要和template代码分 ...
 - 在使用 vscode 时 eslint  检测 .vue 文件中的less 部分内容
		
问题: 在使用 vscode 以及 eslint 来检测 基于 webpack 的 vue-cli 的项目中,eslint 无法检测到 .vue 文件中的less 部分内容. 解答: 1.通过 下载 ...
 - Atom 编辑器安装 linter-eslint 插件,并配置使其支持 vue 文件中的 js 格式校验
		
安装方式有如下几种. 1.最常用的安装方式. # 进入atom插件文件夹 cd ~/.atom/packages/ # git clone 插件源文件 git clone https://github ...
 - 在.vue文件中让html代码自动补全的方法(支持vscode)
		
在.vue文件中让html代码自动补全的方法(支持vscode) https://blog.csdn.net/qq_36529459/article/details/79196763 "fi ...
 - vue 封装 axios 和 各类的请求,以及引入 .vue 文件中使用
		
//src 底下建立 api 文件夹 // api 文件夹下建立 request,js 文件,文件内容复制下面这段代码即可 /** * ajax请求配置 */ import axios fro ...
 
随机推荐
- RDLC后台自己定义报表模板
			
首先封装一个公共类,统一来操作RDLC报表 using System; using System.Collections.Generic; using System.Linq; using Syste ...
 - 使用tencent协议发起临时会话
			
调用默认浏览器打开链接tencent://message/?uin=QQ即可发起临时会话参数uin为目标QQ Java示例 import java.awt.Desktop; import java.n ...
 - 【腾讯bugly干货分享】精神哥手把手教你怎样智斗ANR
			
上帝说要有ANR,于是Bugly就有了ANR上报.那么ANR究竟是什么? 近期非常多童鞋问起精神哥ANR的问题,那么这次就来聊一下,鸡爪怎么泡才好吃.噢不,是怎样高速定位ANR. ANR是什么 简单说 ...
 - 怎样在QML中利用Sprite来做我们须要的动画
			
在游戏中动画的设计很中要. 在QML中,它提供了丰富的animation.可是有时我们须要对图像进行变化,就像放电影一样.在今天的这篇文章中,我们将设计一个能够变化图像的动画. 我们能够通过Qt所提供 ...
 - C语言中的声明与定义的差别
			
1.对于以下的声明语句 int a; 假设其位置出如今全部的函数体之外,那么它就被称为外部对象a的定义.这个语句说明了a是一个外部整型变量,同一时候为a分配了存储空间.由于外部对象a并没 ...
 - mysql 数据库导入错误:40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET
			
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;/*!40101 SET @OLD_CHARACTER_SET_RES ...
 - 关于在PHP中当一个请求未完成时,再发起另一个请求被阻塞的问题
			
最近做项目的时候遇到个问题,就是做阿里云oss大文件上传进度条显示,因为要实时查询上传分片进度,所以在上传的同时必须要再发起查询的请求,但是一直都是所有分片上传完成后查询的请求才执行,刚开始以为是阿里 ...
 - Delphi ActiveForm发布全攻略
			
论坛上很多朋友(也包括我)提到ActiveForm的发布问题,都没有得到很好的解决.下面是本人开发ActiveForm的一点经验,拿出来跟大家分享,开发环境为 Win2000Server,IIS5.0 ...
 - SDIO卡 了解
			
SDIO接口是在SD接口基础上发展起来的,SDIO接口兼容SD接口.SDIO协议又在SD卡协议之上添加了CMD52(一般用来访问寄存器)和CMD53(字节和块传输)命令.SDIO和SD卡规范间的一个重 ...
 - 关于LAMP配置Let’s Encrypt SSL证书
			
昨天建站,买VPS,先装了LAMP,部署wordpress,测试OK了,然后才买的域名,申请SSL证书. 结果Let’s Encrypt cerbot申请证书遇到了麻烦,--apache参数怎么也识别 ...
 
			
		