scoped能够实现style只做用于当前的.vue文件css
<template> <div class="user"></div> </template> <script> </script> <style lang='less' scoped> .user { color:#333; } </style>
上面的文件渲染出的dom结构会是这样的vue
<div data-v-53795c54 class="user"></div>
css样式是这样的less
.user[data-v-53795c54] { color:#333; }
这样就现实了样式只做用于当前.vue文件。dom
缘由是,css被构建成.user[data-v-53795c54]
可是doc节点依然是普通的<div class="user"></div>
,致使样式不能做用在dom上而失效。
缘由在引用的组件上,解决的方法是将scoped属性关闭。spa
若是须要将scoped关闭,那么style就是做用于整个单页应用
但是咱们仍然想要样式之做用于当前的.vue文件,减小对其余文件样式的影响code
1.给template
下的根节点加一个class
,并基于这个class
添加样式ip
<template> <div class="user"> <p class="name">zaunk</p> </div> </template> <script> </script> <style lang='less> .user { color:#333; .name { color:#122222; } } </style>
2.基于第一条建议,不要有定义两个相同class名称的根节点,由于都做用于整个单页会有一个失效。
3.不要使用 span {}
这种作样式设置。由于class
<template> <div class="user"> <el-button class="name">zaunk</el-button> </div> </template> <style lang='less> .user { color:#333; span { color:#122222; } } </style>
上面的样式一样会做用于组件el-button
,这是很危险的渲染
开启scoped样式没有起做用的建议引用
对于没有生效的样式,咱们能够新增一个scoped.css
的文件在main.js
中引用。
普通的css是能够做用于这种dom节点的
.user { color:#ccc; }
<div data-v-53795c54 class="user"></div>