Vue webpack打包后,css样式发生改变或者不起作用
来源:honey缘木鱼     阅读:1219
云上智慧
发布于 2018-12-13 23:17
查看主页

用run dev build打包后,发现样式改变了,最终发现addAdress.vue和myAdress.vue中的有个类名是相同的,但是想着

<style  scoped></style>

在style标签上增加scoped属性,就表示它的样式作用于当下的板块,样式私有化的目的就不会相互污染啊!为什么打包后会出现这样的结果呢!不太了解!

一.css样式发生改变

<style scoped>的scoped属性:

1)加了scoped属性的组件,可以维护当前组件样式不受其它组件影响

2)加了scoped属性的父级组件,不能修改子组件元素样式(无路子组件加没属性scoped,由于scoped只能维护当前组件元素)

3)不加scoped属性的父级组件,可以修改子组件样式

4)加了scoped属性的父级组件,也可以强行控制加了scoped属性的子组件,方法是:.a >>> .b或者者css预解决中的 .a /deep/

二.css样式不起作用

起因:

1.使用了webpack2的语法规则不正确; webpack2要求必需写-loader;

2.可能是只写了css-loader,没有写style-loader;

3.顺序反了,必需写成 style-loader!css-loader;

没写style-loader则build文件会生成,但你会发现页面中js不起作用;

没写css-loader则会直接报错:’You may need an appropriate loader to handle this file type.’

style-loader只是没起作用而不报错就意味着它的作用是将样式插入到DOM元素中;结合网上的答案以及观察预览页面发现:style-loader会在页面的header标签里生成内部的<style></style>;

css-loader 会报错,是由于它影响到webpack的build的过程了。结合网上分享以及’You may need an appropriate loader to handle this file type.’报错信息,意味着css-loader的存在使得在js中通过require或者者import引入css成功;通过css-loader,可以实现在js文件中通过require的方式,来引入css。

免责声明:本文为用户发表,不代表网站立场,仅供参考,不构成引导等用途。 系统环境 服务器应用
相关推荐
10 条加速 Ubuntu Linux 的杀手级技巧
使用TensorRT对caffe和pytorch onnx版本的mnist模型进行fp32和fp16 推理 |  tensorrt fp32 fp16 tutorial with caffe p...
前台面试每日 3+1 —— 第631天
web前台入门到实战:纯CSS3仿网易云孤独星球特效
利用Python实现前台自动化打包部署
首页
搜索
订单
购物车
我的