vue.js scoped样式辩说

打印 上一主题 下一主题

主题 559|帖子 559|积分 1677

在Vue.js中,偶然候我们希望组件的样式只在组件内部生效,而不会影响到其他组件或全局样式。为了实现这个目标,Vue.js提供了scoped样式的功能。
scoped样式是通过给组件的style标签添加scoped属性来实现的,例如:
  1. <template>
  2.   <div class="component">
  3.     <p class="text">This is a scoped style example.</p>
  4.   </div>
  5. </template>
  6. <style scoped>
  7. .component {
  8.   background-color: red;
  9. }
  10. .text {
  11.   color: blue;
  12. }
  13. </style>
复制代码

上述代码中,.component和.text类的样式只会应用到当前组件的元素上,并不会影响到其他组件或全局样式。
然而,当组件的样式中存在选择器嵌套或利用了全局选择器时,可能会导致scoped样式辩说的题目。
首先,当你在组件的样式中利用了嵌套选择器,例如:
  1. <template>
  2.   <div class="component">
  3.     <p class="text">This is a scoped style example.</p>
  4.   </div>
  5. </template>
  6. <style scoped>
  7. .component {
  8.   background-color: red;
  9. }
  10. .component p {
  11.   color: blue;
  12. }
  13. </style>
复制代码

以上代码中,.component p选择器是嵌套在.component选择器中的。这种情况下,Vue.js会自动生成一个唯一的属性并添加到选择器中,以确保样式只应用到当前组件的元素上。生成的唯一属性雷同于data-v-xxxxxxx。
  1. <template>
  2.   <div class="component" data-v-xxxxxxx>
  3.     <p class="text" data-v-xxxxxxx>This is a scoped style example.</p>
  4.   </div>
  5. </template>
复制代码

但是,当你在样式中利用全局选择器时(例如body、html),scoped样式就会失效,由于Vue.js无法修改外部元素的样式。
解决scoped样式辩说的一种常见做法是利用特殊的类名前缀,例如:
  1. <template>
  2.   <div class="component">
  3.     <p class="component-text">This is a scoped style example.</p>
  4.   </div>
  5. </template>
  6. <style scoped>
  7. .component {
  8.   background-color: red;
  9. }
  10. .component-text {
  11.   color: blue;
  12. }
  13. </style>
复制代码

通过给组件内部的类名添加特殊的前缀,可以镌汰样式辩说的可能性。
另外,如果你需要在组件的样式中利用全局选择器,可以利用/deep/或>>>来举行穿透,例如:
  1. <template>
  2.   <div class="component">
  3.     <p class="text">This is a scoped style example.</p>
  4.   </div>
  5. </template>
  6. <style scoped>
  7. .component {
  8.   background-color: red;
  9. }
  10. /deep/ .text {
  11.   color: blue;
  12. }
  13. </style>
复制代码

上述代码中,/deep/ .text选择器会穿透scoped样式,应用到全部的.text类元素上。
需要注意的是,/deep/以及>>>只在利用了预处理器(如Sass、Less)时才会生效,在普通CSS中是无效的。
综上所述,Vue.js的scoped样式可以很好地解决组件样式辩说的题目。通过利用scoped属性来限定样式的作用范围,以及利用特殊的类名前缀或/ deep / >>>来处理选择器嵌套和全局选择器,可以有效地克制样式辩说并保持样式的隔离。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

星球的眼睛

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表