踩坑:1.样式污染 2.父子组件样式互相影响

一、造成样式污染的可能:

1.单组件:未使用scoped关键字导致样式泄露,污染全局

应采用:

<style scoped>
</style>

2.多组件:公共css文件,多组件引用

原因:<style scoped> @import "assets/css/common.css"; </style>

虽然加了scoped,最后无效的原因是“@import”,原因如下:
@import并不是直接引入css代码到页面,而是发起新的不带scoped的请求获得样式资源;因此,这种引用方式是全局的,从而引起全局污染。

应采用:src引入方式

<style lang="scss" scoped src="@/styles/common.scss">
</style>

二、父子组件样式互相影响

参考链接:vue 父组件样式影响子组件_vue父组件样式影响子组件-优快云博客

1.目的:避免父子组件样式互相影响

问题:父子两个组件的style标签都使用了scoped属性,但是子组件的根组件样式受到父组件的样式影响。

原因:vue的单文件组件是通过vue-loader加载的

使用 scoped 后,父组件的样式将不会渗透到子组件中。不过一个子组件的根节点会同时受其父组件的 scoped CSS 和子组件的 scoped CSS 的影响。这样设计是为了让父组件可以从布局的角度出发,调整其子组件根元素的样式。

解决方法:待补充

2.目的:父组件样式影响多个子组件,实现代码复用,但是不泄露污染到别的组件

解决方法:待补充

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值