首页 / VUE / Vue 组件间的样式冲突污染
Vue 组件间的样式冲突污染
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Vue 组件间的样式冲突污染,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2014字,纯文字阅读大概需要3分钟。
内容图文
![Vue 组件间的样式冲突污染](/upload/InfoBanner/zyjiaocheng/342/14cadc684b51460abb1ecd097352b43a.jpg)
一、污染是如何产生的?
得益于 Vue-loader,在 Vue 中可以使用类似于 Web Component 的组件化写法, <template></template><style></style><script></script>
,在大多数情况下,我们希望组件间定义的样式是相互隔离的,在 Weex 当中的确如此,组件天生隔离,可是在 Vue 当中,运行的载体还是浏览器,所有的样式类还是会通过 style 标签插入头部,影响全局,交叉污染
二、增加 Scoped 标识
依然是 Vue-loader,通过为组件中的 style 标签增加一个 scoped 标识,Vue-loader 在编译的过程中会为组件每一个元素节点增加 scopeId 作为属性,同时为所有的样式类加上属性选择器 scopeId,从而达到隔离的效果,大概是下面的样子:
每个组件有唯一的 scopeId,按理说,这样应该能够做到样式隔离了,实际上, 这种方式其实表现已经足够好了,除了以下这种情况~~
三、ScopeId 的继承
我们把上面的例子再完善下:
// 父组件 <template> <div> <div class="bg"></div> <Sub></Sub> </div> </template> <script> import Sub from './sub'; export default { components: { Sub } }; </script> <style scoped> .bg { background-color: #000; width: 100px; height: 100px; } </style> // 子组件 <template> <div class="bg"> </div> </template> <script> export default { }; </script> <style scoped> .bg { width: 300px; height: 300px; margin-top: 5px; } </style>
由于我们使用了 scoped 标识进行样式隔离,子组件的 div 不应该有任何背景颜色,可是现实总在狠狠的打脸~~
不知道你的媚眼看到问题的所在了没:
子元素的 根元素 会继承父元素的 ScopeId!
子元素的 根元素 会继承父元素的 ScopeId!
子元素的 根元素 会继承父元素的 ScopeId!(说了三遍的话,肯定很重要)
由于子元素的 根元素 除了拥有自己的 ScopeId 属性,还继承了父元素的 ScopeId 属性,所以父元素的样式类 bg 对其依然有效
四、怎么破?
破解的方式也很简单,为每一个组件的根元素提供一个另类一点的样式名(如果有的话),例如就不要每个组件都命名为:wrap,根据业务名为:b1-wrap、b2-wrap 等
组件中的非根元素,类名不管怎么命名,怎么重名,都是不会发生污染的,这个自己领悟~~
五、这应当属于 Vue-loader 的一个 bug
没错,这应该是一个 bug,如果是我应该会怎么解呢,编译的时候不是增加属性,而是直接根据 scopeId 修改类名,嘿嘿~~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
内容总结
以上是互联网集市为您收集整理的Vue 组件间的样式冲突污染全部内容,希望文章能够帮你解决Vue 组件间的样式冲突污染所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。