vue-cli3 npm run build 打包后静态资源的配置 vue.config.js的配置

vue.config.js配置如下:

 

const path = require('path');

const vConsolePlugin = require('vconsole-webpack-plugin'); // 引入 移动端模拟开发者工具 插件 (另:https://github.com/liriliri/eruda)

const CompressionPlugin = require('compression-webpack-plugin'); //Gzip

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; //Webpack包文件分析器

const baseUrl = process.env.NODE_ENV === "production" ? "/static/" : "/"; //font scss资源路径 不同环境切换控制

 

module.exports = {

  //基本路径

  baseUrl: './',

  //输出文件目录

  outputDir: 'dist',

  // eslint-loader 是否在保存的时候检查

  lintOnSave: true,

  //放置生成的静态资源 (js、css、img、fonts) 的 (相对于 outputDir 的) 目录。

  assetsDir: 'static',

  //以多页模式构建应用程序。

  pages: undefined,

  //是否使用包含运行时编译器的 Vue 构建版本

  runtimeCompiler: false,

  //是否为 Babel 或 TypeScript 使用 thread-loader。该选项在系统的 CPU 有多于一个内核时自动启用,仅作用于生产构建,在适当的时候开启几个子进程去并发的执行压缩

  parallel: require('os').cpus().length > 1,

  //生产环境是否生成 sourceMap 文件,一般情况不建议打开

  productionSourceMap: false,

  // webpack配置

  //对内部的 webpack 配置进行更细粒度的修改 https://github.com/neutrinojs/webpack-chain see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md

  chainWebpack: config => {

    /**

     * 删除懒加载模块的prefetch,降低带宽压力

     * https://cli.vuejs.org/zh/guide/html-and-static-assets.html#prefetch

     * 而且预渲染时生成的prefetch标签是modern版本的,低版本浏览器是不需要的

     */

    //    config.plugins.delete('prefetch');

    //    if(process.env.NODE_ENV === 'production') { // 为生产环境修改配置...process.env.NODE_ENV !== 'development'

    //    } else {// 为开发环境修改配置...

    //    }

  },

  //调整 webpack 配置 https://cli.vuejs.org/zh/guide/webpack.html#%E7%AE%80%E5%8D%95%E7%9A%84%E9%85%8D%E7%BD%AE%E6%96%B9%E5%BC%8F

  configureWebpack: config => {

    //生产and测试环境

    let pluginsPro = [

      new CompressionPlugin({ //文件开启Gzip,也可以通过服务端(如:nginx)(https://github.com/webpack-contrib/compression-webpack-plugin)

        filename: '[path].gz[query]',

        algorithm: 'gzip',

        test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$', ),

        threshold: 8192,

        minRatio: 0.8,

      }),

      //  Webpack包文件分析器(https://github.com/webpack-contrib/webpack-bundle-analyzer)

      new BundleAnalyzerPlugin(),

    ];

    //开发环境

    let pluginsDev = [

      //移动端模拟开发者工具(https://github.com/diamont1001/vconsole-webpack-plugin https://github.com/Tencent/vConsole)

      new vConsolePlugin({

        filter: [], // 需要过滤的入口文件

        enable: false // 发布代码前记得改回 false

      }),

    ];

    if(process.env.NODE_ENV === 'production') { // 为生产环境修改配置...process.env.NODE_ENV !== 'development'

      config.plugins = [...config.plugins, ...pluginsPro];

    } else {

      // 为开发环境修改配置...

      config.plugins = [...config.plugins, ...pluginsDev];

    }

  },

  css: {

    // 启用 CSS modules

    modules: false,

    // 是否使用css分离插件

    extract: true,

    // 开启 CSS source maps,一般不建议开启

    sourceMap: false,

    // css预设器配置项

    loaderOptions: {

      sass: {

        //设置css中引用文件的路径,引入通用使用的scss文件(如包含的@mixin)

        data: `

        $baseUrl: "/";

      `

      }

    }

  },

  // webpack-dev-server 相关配置 https://webpack.js.org/configuration/dev-server/

  devServer: {

    host: 'localhost',

    // host: "0.0.0.0",

    port: 8000, // 端口号

    https: false, // https:{type:Boolean}

    open: true, //配置自动启动浏览器 http://XXX.XXX.X.XX:7071/rest/XXX/

    hotOnly: true, // 热更新

    proxy: 'http://localhost:8000' // 配置跨域处理,只有一个代理

    // proxy: { //配置自动启动浏览器

    //  "/XX/*": {

    //    target: "http://XXX.XXX.X.XX",

    //    changeOrigin: true,

    //    // ws: true,//websocket支持

    //    secure: false

    //  },

    //  "/x/*": {

    //    target: "http://XXX.XXX.X.XX",

    //    changeOrigin: true,

    //    // ws: true,//websocket支持

    //    secure: false

    //  },

    // }

  },

 

  // 第三方插件配置 https://www.npmjs.com/package/vue-cli-plugin-style-resources-loader

  pluginOptions: {

    'style-resources-loader': {//https://github.com/yenshih/style-resources-loader

      preProcessor: 'scss',//声明类型

      'patterns': [

//        path.resolve(__dirname, './src/assets/scss/_common.scss'),

      ],

//      injector: 'append'

    }

  }

};

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值