本人全部文章首发在博客园: www.cnblogs.com/zhangrunhao…css
在人生就要绝望的时候, 被编辑器所提示的一个
scopedSlots
所拯救. 卧槽, 写到最后才发现这个属性的具体卵用. 详情见最后解决办法.html
.vue
文件.<template>
中使用$style:[类名]
, <style module>
进行了样式的绑定.<template>
<span :class="$style.text">
...
</span>
</template>
<style module> .text {} </style>
复制代码
module
这个属性的具体含义scoped
造成独立做用域后, 并不能影响到elemnt中组件的样式.scopedSlots
标识style标签后, 解决问题. 但出现 dev环境正常, 部署后, 不起做用.vue
的<style>
标签这应该是关系到,
vue-loader
这个webpack的插件vue
vue-laoder
会解析组件, 提取语言块. 在须要的时候, 通过其余的loader处理, 最后组装成一个commonjs模块.
export default出来一个对象
而后呢, 上面的<template>
, 挂载在 这个对象的template属性上
<style>
能够有module和scoped属性, 来将样式封装到组件中. 具备不一样封装模式的多个<style>
标签, 能够在一个组件中混合使用style-loader
会提取内容, 并经过<style>
标签, 加入到文档的<head>
中. 也能够经过配置webpack造成单个.css文件.$style
配合<module>
如何工做参考: vue-loader-v14.vuejs.org/zh-cn/featu…webpack
<style>
中使用一个module
属性, 能够造成名为$style
的计算属性<span :class="$style.text">
...
</span>
复制代码
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)
进行访问web
可使用module=''
来更改$style
这个名称框架
<div :class="aaa.root">
</div>
<style lang="less" module="aaa"> </style>
复制代码
scoped
的做用域是如何的<style></style>
标签有scoped
属性的时候, 他的css样式只做用在当前做用域scoped
以后, 父组件的样式不会再深刻到自组件.
>>>
或者是 /deep/
stylus
起做用, scss
不起做用, 并未验证v-html
动态生成的样式不受做用域内样式影响, 但我想应该加个类样式名称,能够解决.(未验证)build
的文件夹中element/packages/theme-chalk/src/menu.scss
, 以方便后期的具体查看scopedSlots
解决我擦哦, 再次测试后, 发现添加
scopedSlots
并无什么卵用, 和什么都不写是他妈一个样子啊.. 我说怎么, 怎么查了半天, 也没人用. 还被这玩意所拯救, 也真是够了.. 当时还骄傲了半天, 还觉得是发现了新天地, 也真是6了.less
scoped
以后, 在子组件上面添加类样式名, 发现并无卵用错误依旧: 只是在表面层上的有一些data-v的注入编辑器
没有找到须要注入到里面的条件, 发现本身前面大部分的判断都是错误的.测试
scoped
方案>>>
语法糖进行样式的注入<style scoped> .main_nav .el-menu .el-submenu >>> .el-submenu__title { background-color: red; } </style>
复制代码
module
方案:global()
进行这个属性下面的所有选择<style lang="less" module="aaa"> .red { .item { :global(.el-submenu__title) { background: red; } } } </style>
复制代码
<style></style>
只有module
和scoped
, 没有其余取巧方案module
造成一个表明属性的计算属性, 默认名称为$style
, 其中的:global()
能够进行这个区域下面的全部元素的选择.scoped
造成的做用域, 能够经过>>>
来进行子组件的样式覆盖, 带只要原生的css支持.