时间:2021-02-03 18:25:11 | 栏目:vue | 点击:次
在写单文件组件时,一般都是把标签、脚本、样式写到一起,这样写个人感觉有点不够简洁,所以就想着把样式分离出去。
采用import加载样式
在局部作用域(scoped)采用@import加载进来的样式文件,想法是美好的。以为这样加载进来的样式文件也只对当前组件有效;可现实是残酷的,这样加载进来的样式无法限制其作用域。
<style scoped> @import "样式文件"; </style>
解决方案
采用 src属性加载样式。
<style src="样式路径" scoped></style>
PS:关于vue单文件组件中样式的问题
在写单文件组件的项目时,遇到过这样的问题。某一个样式类,明明我只写了两个padding,但是在我用webpack
构建之后,莫名其妙的多出了很多其他的样式。
后来,无意中看见别人的提问中,说如何解决单文件组件中样式同名的问题。
我就想,会不会是不同的.vue文件里使用了同名类的原因。
于是,我在style标签后面加上了scoped这个关键字之后,再npm run build,果然好了。
原因:
不加scoped表示样式是全局共享的。
加上了scoped就是这个样式只能在这个.vue文件里面有效。
总结