请问vue-cli 4.x中,怎么把.vue文件的style样式都打包到一个css文件中?

发布于 2022-09-12 02:09:35 字数 1436 浏览 19 评论 0

在我安装的这个版本的@vue/cli 4.2.3,我的vue.congif.js基本采用系统默认的配置

vue.config.js

const path = require('path')

module.exports = {
    devServer: {
        open: false,
        overlay: {
            warnings: false,
            errors: true
        }
    },
    chainWebpack(config) {
        // 在这里我把prefetch去掉了
        config.plugins.delete('prefetch')
        config.when(process.env.NODE_ENV === 'production', config => {
            config.optimization.splitChunks({
                chunks: 'all'
            })
        })
    },
    configureWebpack: {
        resolve: {
            alias: {
                '@$': path.resolve('src')
            }
        }
    },
    publicPath: '/',
    lintOnSave: process.env.NODE_ENV !== 'production',
    productionSourceMap: false
}

打包截图

image.png
每一个.vue组件的style都被剥离出来成为单独的css,这样看起来用到时加载很节省带宽,我把prefetch预加载去掉了,但是实际体验中,会存在一些动态显示的组件主线短暂空白,在一个复杂的组件里,比如多个tab,一次性要加载js和css的数量达到10个,空白甚至能达到1秒
我尝试很多网上的方法
其中
vava熊的方法

//!多个css chunk合并成一个css文件 
styles: { 
    name: 'styles', 
    test: /\.(scss|sass|less|css)$/, 
    chunks: 'all', 
    minChunks: 1, 
    reuseExistingChunk: true 
}

并不能把vue里的style合并到一起
所以请问怎么配置才可以把vue的style合并到一个css内?谢谢了

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文