关于.vue文件中style的scoped属性

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

问题:添加scoped属性后样式不起做用

缘由是,css被构建成.user[data-v-53795c54] 可是doc节点依然是普通的
<div class="user"></div>,致使样式不能做用在dom上而失效。
缘由在引用的组件上,解决的方法是将scoped属性关闭。spa

scoped关闭时的使用建议

若是须要将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>
相关文章
相关标签/搜索