vue技巧(十)全局配置使用(打包后可修改配置文件)

1、背景        

        vue打包目前主流用的有webpack和vite两种,默认用的webpack。(二者的区别大家可以各自上网查,我没用过vite,所以不过多介绍)vue通过webpack打包后,源码会被压缩,但一些关键配置可能需要根据运行环境的变化而手动修改。本篇文章则主要介绍如何让配置文件在打包后保持不变,进而支持后期手动修改配置文件中的参数。

2、实现方法

方法一:配置文件放置到public目录下(最简单、推荐使用)

webpack打包时会整个复制public里面的文件,因此放置在其中的配置文件不会受到任何影响。

配置使用方法:

方法二:基于generate-asset-webpack-plugin插件

首先安装插件:

npm install --save-dev generate-asset-webpack-plugin

其次在vue配置文件中声明打包时重新生成指定的配置文件,配置如下:

const GenerateAssetPlugin = require('generate-asset-webpack-plugin')
const globalConfig = require('./src/static/globalConfig.json')
module.exports={
    configureWebpack:{
        performance: {
            hints: false
          },
        plugins: [
            new GenerateAssetPlugin({
              filename: 'globalConfig.json',
              fn: (compilation, cb) => {
                cb(null, JSON.stringify(globalConfig))
              },
              extraFiles: []
            })
        ]
     }
}

注意:这里其实是重新生成一个配置文件,所以使用的是json类型的配置文件。另外我用的webpack版本太高,跟插件不匹配,编译时报错:编译报错compiler.plugin is not a function。解决方式是修改插件源码,修改过程可参考该文章(新安webpack插件后编译报错compiler.plugin is not a function-CSDN博客)。打包后目录如下:

在代码中使用该配置文件的方法与使用js类型配置文件类似,如下所示:

3、总结:

1)方式一展示了js格式配置的使用方式,方式二展示了json格式配置的使用方式。

2)配置文件一般有.js或.json两种,方式一使用js或者json配置都可以,方式二则推荐用json,因为方式二如果使用js的话,上面的拷贝代码会报错。

3)webpack版本太高与插件不兼容,编译报错compiler.plugin is not a function,可以通过修改源码解决,解决方式参考该文章:新安webpack插件后编译报错compiler.plugin is not a function-CSDN博客

4)还有一种常见的配置使用思路,就是提前创建好多个配置文件,然后根据不同的运行环境让框架自动选择某一个配置文件使用。但这种方法使用的前提是所有环境和配置是已知的才行。

相关推荐

  1. vue2打包,接口地址打包文件配置

    2024-06-14 07:40:03       62 阅读
  2. vue3 配置全局@符号

    2024-06-14 07:40:03       22 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-14 07:40:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-14 07:40:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-14 07:40:03       82 阅读
  4. Python语言-面向对象

    2024-06-14 07:40:03       91 阅读

热门阅读

  1. WHAT - React 学习系列(一)

    2024-06-14 07:40:03       25 阅读
  2. .NET C# 实现国密算法加解密

    2024-06-14 07:40:03       18 阅读
  3. VB.net与C# 调用InitializeComponent的区别

    2024-06-14 07:40:03       28 阅读
  4. HarmonyOS(35) @State使用注意事项

    2024-06-14 07:40:03       23 阅读
  5. php学习笔记

    2024-06-14 07:40:03       30 阅读
  6. Android基础-应用的启动流程

    2024-06-14 07:40:03       31 阅读
  7. 19.2 HTTP客户端-定制HTTP请求、调试HTTP、响应超时

    2024-06-14 07:40:03       23 阅读
  8. Hadoop 3.X HA集群部署

    2024-06-14 07:40:03       23 阅读