scoped css
2019-08-19 11:13
976 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/mm0715/article/details/99716671
作用域CSS
当<style>标记具有该scoped属性时,其CSS将仅应用于当前组件的元素。这类似于Shadow DOM中的样式封装。它有一些警告,但不需要任何polyfill。通过使用PostCSS转换以下内容来实现:
<style scoped> .example { color: red; } </style> <template> <div class="example">hi</div> </template>
转换之后:
<style> .example[data-v-f3f3eg9] { color: red; } </style> <template> <div class="example" data-v-f3f3eg9>hi</div> </template>
混合本地和全局样式
您可以在同一组件中包含范围和非范围样式:
<style> /* global styles */ </style> <style scoped> /* local styles */ </style>
子组件根元素
使用时scoped,父组件的样式不会泄漏到子组件中。但是,子组件的根节点将受父级作用域CSS和子级作用域CSS的影响。这样设计以便父级可以设置子根元素的样式以进行布局。
深度选择器
如果您希望scoped样式中的选择器“深入”,即影响子组件,则可以使用>>>组合子:
<style scoped> .a >>> .b { /* ... */ } </style>
以上将编译成:
.a[data-v-f3f3eg9] .b { /* ... */ }
某些预处理器(如Sass)可能无法>>>正确解析。在这些情况下,您可以使用组合/deep/或::v-deep组合 - 两者都是别名,>>>并且工作完全相同。
动态生成的内容
创建的DOM内容v-html不受范围样式的影响,但您仍可以使用深度选择器设置它们的样式
相关文章推荐
- Vue scoped CSS 与深度作用选择器 /deep/
- Vue: scoped 样式与 CSS Module 对比
- Saving the Day with Scoped CSS
- Vue style里面使用scoped属性并@import引入外部css, 作用域是全局的解决方案
- Vue中对比scoped css和css module的区别
- 〖網頁·CSS〗CSS笔记
- 第一天 XHTML CSS基础知识 文章出处:标准之路(http://www.aa25.cn)
- 使用css控制table的cellspacing和cellpadding属性
- JS判断移动端访问设备并解析对应CSS
- CSS中单位PX Vs EM 及弹性布局
- CSS属性书写规范
- 创建一个纯CSS下拉菜单
- css默认值汇总
- HTML中引入外部CSS和JS
- 使用css让文字两端对齐
- CSS常用小技巧
- css-4.边框和盒子模型
- CSS之内容移出
- 强大的CSS:模拟下雪效果动画制作教程
- CSS中文手册.chm