详解.vue文件中style标签的几个标识符
网络编程 2021-07-04 16:46www.168986.cn编程入门
这篇文章主要介绍了详解.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处理, 组装成一个monjs模块.- 其实就是
export default出来一个对象
然后呢, 上面的<template>
, 挂载在这个对象的template属性上
- 之前, 直接import引近来一些样式文件也是可行的, 但当时并未思考这些标识如何实现.
- 其实就是
<style>
可以有module和scoped属性, 来将样式封装到组件中. 具有不同封装模式的多个<style>
标签, 可以在一个组件中混合使用- 默认情况下,
style-loader
会提取内容, 并通过<style>
标签, 加入到文档的<head>
中. 也可以通过配置webpack形成单个.css文件.
$style
配合<module>
如何工作
参考:
在<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狼蚁网站SEO优化不起作用
- 已验证: 在普通的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()进行这个属性狼蚁网站SEO优化的全部选择
- 进而选中这个没有在作用域狼蚁网站SEO优化可以选择到的元素
- 个人始终认为这种选择方案, 可以做到css作用域的区分, , 并不灵活
- 具体的以后再分析
<style lang="less" module="aaa"> .red { .item { :global(.el-submenu__title) { background: red; } } } </style>
- .vue文件中的
<style></style>
只有module
和scoped
, 没有其他取巧方案 module
形成一个代表属性的计算属性, 默认名称为$style
, 其中的:global()
可以进行这个区域狼蚁网站SEO优化的所有元素的选择.scoped
形成的作用域, 可以通过>>>
来进行子组件的样式覆盖, 带只要原生的css支持.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程