这篇文章主要为大家详细介绍了分析.vue文件中style标签的几个标识符,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!
在人生就要绝望的时候, 被编辑器所提示的一个scopedSlots
所拯救.
卧槽, 写到最后才发现这个属性的具体卵用. 详情见最后解决办法.
代码如下:
<template>
<span :class="$style.text">
...
</span>
</template>
<style module>
.text {}
</style>
module
这个属性的具体含义scoped
形成独立作用域后, 并不能影响到elemnt中组件的样式.scopedSlots
标识style标签后, 解决问题. 但出现 dev环境正常, 部署后, 不起作用
认识.vue
的<style>
标签
这应该是关系到, vue-loader
这个webpack的插件
vue-laoder
会解析组件, 提取语言块. 在需要的时候, 经过其他的loader处理, 最后组装成一个commonjs模块.
export default出来一个对象
然后呢, 上面的<template>
, 挂载在 这个对象的template属性上
<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语法.
isRed
这个属性是true
的话, 就会添加上red
这个属性名代码如下:
<span :class="{[$style.red] : isRed}">
测试
</span>
<script>
data() {
return {
entries: [],
isRed: true,
};
},
</script>
<style module>
.red {
color: red;
}
</style>
console.log(this.$style.red)
进行访问module=''
来更改$style
这个名称代码如下:
<div :class="aaa.root">
</div>
<style lang="less" module="aaa">
</style>
scoped
的作用域是如何的
当<style></style>
标签有scoped
属性的时候, 他的css样式只作用在当前作用域
使用了scoped
之后, 父组件的样式不会再深入到自组件.
深度作用选择器: >>>
或者是 /deep/
stylus
起作用, scss
不起作用, 并未验证v-html
动态生成的样式不受作用域内样式影响, 但我想应该加个类样式名称,可以解决.(未验证)
css的作用域的渲染方式, 远不如class的渲染速度
递归组件中, 小心使用CSS样式.
build
的文件夹中element/packages/theme-chalk/src/menu.scss
, 以方便后期的具体查看
使用scopedSlots
解决
我擦哦, 再次测试后, 发现添加scopedSlots
并没有什么卵用, 和什么都不写是他妈一个样子啊.. 我说怎么, 怎么查了半天, 也没人用.
还被这玩意所拯救, 也真是够了..
当时还骄傲了半天, 还以为是发现了新天地, 也真是6了.
添加scoped
之后, 在子组件上面添加类样式名, 发现并没有卵用
错误依旧: 只是在表面层上的有一些data-v的注入
【图片暂缺】
没有找到需要注入到里面的条件, 发现自己前面大部分的判断都是错误的.
解决方案一:scoped
方案
>>>
语法糖进行样式的注入代码如下:
<style scoped>
.main_nav .el-menu .el-submenu >>> .el-submenu__title {
background-color: red;
}
</style>
解决方案二: module
方案
代码如下:
<style lang="less" module="aaa">
.red {
.item {
:global(.el-submenu__title) {
background: red;
}
}
}
</style>
【图片暂缺】
<style></style>
只有module
和scoped
, 没有其他取巧方案module
形成一个代表属性的计算属性, 默认名称为$style
, 其中的:global()
可以进行这个区域下面的所有元素的选择.scoped
形成的作用域, 可以通过>>>
来进行子组件的样式覆盖, 带只要原生的css支持.以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持四海网。
本文来自:http://www.q1010.com/184/5238-0.html
注:关于分析.vue文件中style标签的几个标识符的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。
关键词:vue.js
四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。