时间:2021-05-18
本文介绍了.vue文件中style的scoped属性以及踩到的坑,具体如下:
scoped可以实现style只作用于当前的.vue文件
上面的文件渲染出的dom结构会是这样的
<div data-v-53795c54 class="user"></div>css样式是这样的
.user[data-v-53795c54] { color:#333;}这样就现实了样式只作用于当前.vue文件。
问题:添加scoped属性后样式不起作用
原因是,css被构建成.user[data-v-53795c54] 但是doc节点依然是普通的<div class="user"></div>,导致样式不能作用在dom上而失效。
原因在引用的组件上,解决的方法是将scoped属性关闭。
scoped关闭时的使用建议
如果需要将scoped关闭,那么style就是作用于整个单页应用
可是我们仍然想要样式之作用于当前的.vue文件,减少对其他文件样式的影响
1、给template下的根节点加一个class,并基于这个class添加样式
2、基于第一条建议,不要有定义两个相同class名称的根节点,因为都作用于整个单页会有一个失效。
3、不要使用 span {}这种做样式设置。因为
上面的样式同样会作用于组件el-button,这是很危险的
在vue组件中style scoped中遇到的坑
在uve组件中我们我们经常需要给style添加scoped来使得当前样式只作用于当前组件的节点。添加scoped之后,实际上vue在背后做的工作是将当前组件的节点添加一个像data-v-1233这样唯一属性的标识,当然也会给当前style的所有样式添加[data-v-1233]这样的话,就可以使得当前样式只作用于当前组件的节点。但是我们需要注意的是如果我们添加了子组件,同样的,如果子组件也用scoped标识了,那么在父组件中是不能设置子组件中的节点的。若父组件有scoped,子组件没有设置,同样,也是不能在父组件中设置子组件的节点的样式的,因为父组件用了scoped,那么父组件中style设置的样式都是唯一的了,不会作用与其他的组件样式,我在用vue-quill-editor富文本编辑器的时候就遇到了这个坑,我只是想让内容区设置一个高度,这样的话,是必须在App.vue中设置的,我们App.vue相当于根容器,没有设置scoped,所以是可以设置的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
问题描述对于.vue的文件来说,也是由结构、行为、样式三部分组成,在样式部分有个scoped的属性,也就是当前页面有效,当style标签内样式比较多时或者.vu
众所周知,在组件中给style标签添加属性scoped属性可以避免组件内样式对外界造成污染,scoped使得组件内的样式变成局域样式,只作用于当前组件。原理如下
特别的,有一个新的属性,它能让我们控制多个元素的属性,就是:scoped。style标记上新出现的这个scoped属性可以让CSS样式只对局部元素生效,具体说,
当标签有scoped属性时,它的CSS只作用于当前组件中的元素。vue组件编译后,会将template中的每个元素加入[data-v-xxxx]属性来确保sty
关于vue.js中class与style绑定的练习代码,分享给大家,供大家参考:html:Vuejs中Class与Style绑定猴猴呀lowrie猴猴呀lowr