vue cli 3.0中的vue.config.js主要配置及解析

在我们创建一个vue项目的时候,vue cli3 不会为我们创建 vue.config.js 文件。

vue.config.js 是一个可选的配置文件,如果项目的根目录中存在这个文件,那么它会在vue项目启动时自动加载。

// 包含选项的对象
module.exports = {
    // 包含的选项
}

 module.exports 是一个包含了各种选项的对象。

// 包含选项的对象
module.exports = {
    // 默认静态资源路径 (可添加相对路径)
    publicPath: "./",
    // publicPath: "/",
}

 在 publicPath 中它可用的值为 Srting 类型,其中 "./" 表示静态资源可以在当前文件夹中找到(相对路径),"/" 表示静态资源在根路径当中可以找到(绝对路径)。

但一般情况是以以下的形式写的:

// 包含选项的对象
module.exports = {
    // 默认静态资源路径 (可添加相对路径) 需要区分 生产环境 和 开发环境
    publicPath: process.env.NODE_ENV === "production" ? "/dist/" : "/",
    // publicPath: process.env.NODE_ENV === "production" ? "./" : "/",
    // build的输出目录 默认为'dist'
    outputDir: "dist"
    // 用于放置生成的静态资源 (js、css、img、fonts);(项目打包之后,静态资源会放在这个文件夹下)
    assetsDir: 'static',
}

这时有人肯定会说用 "/" 或者 "./" 不就行了吗?但为什么要写 process.env.NODE_ENV === "production" ? "/dist/" : "/" 或 process.env.NODE_ENV === "production" ? "./" : "/" 呢?

因为当vue项目被打包后会被放到 dist 目录之中,在运行时,路径会变成 **/dist/** 导致静态资源不能展现。

ps:outputDir 默认为 dist 目录。

 用 lintOnSave 来设置是否每次保存进行代码检测,一般会使用 process.env.NODE_ENV === 'development' 来进行判断,开发环境使用,生产环境不使用。

 如果你不需要生产环境的 source map,可以将 productionSourceMap 设置为 false 以加速生产环境构建用。

// 包含选项的对象
module.exports = {
    // 是否每次保存进行代码检测
    lintOnSave: process.env.NODE_ENV === 'development',
    // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
    productionSourceMap: false,
}

 到目前为止一些比较常用的就介绍完了,现在需要对最重要的 devServer 进行了解了。

 devServer 最简单的理解,就是前端需要进行请求后端所提供的接口时,对请求进行拦截和处理的一个中间组件。

在 devServer 中最常用的参数为以下几种:

// 包含选项的对象
module.exports = {
    devServer: {
        open: true,                 // 启动后自动打开默认浏览器
        host: '0.0.0.0',            // 启动时使用的域名
        port: 8080,                 // 指定端口号
        https: false,               // 是否使用https协议
        hotOnly: false,             // 是否打开热更新
        disableHostCheck: true,     // 是否关闭HOST检查, 关闭后可以接受来自任何HOST的请求
        proxy: ""                   // 跨域配置
        }
    }
}

最简单的一种跨域是直接使用 proxy ,如下所示:

module.exports = {
    devServer: {
        proxy: 'http://123.123.12.1:8080'
    }
}

 意思就是将所有请求代理到 'http://123.123.12.1:8080' 之中去。比如:

之前的响应地址为 http://192.234.14.7:8848/login

                                                ↓↓↓↓↓

代码运行后结果就为 http://123.123.12.1:8080/login

 但一般情况下都是以以下的方式来请求代理的:

// 包含选项的对象
module.exports = {
    devServer: {
        open: true,                 // 启动后自动打开默认浏览器
        host: '0.0.0.0',            // 启动时使用的域名
        port: 8080,                 // 指定端口号
        https: false,               // 是否使用https协议
        hotOnly: false,             // 是否打开热更新
        disableHostCheck: true,     // 是否关闭HOST检查, 关闭后可以接受来自任何HOST的请求
        proxy: {
            '/api': {
            // '/api' 的意义在于,声明axios中url已/api开头的请求都适用于该规则,
            // 注意是以/api开头,即:axios.post({url: '/api/xxx/xxx'})
                // 目标服务器地址
                target: '',
                // 代理websockets
                ws: true,
                // 开启代理 (允许跨域)
                changeOrigin: true,
                pathRewrite: {
                    //重写路径 比如'/api/aaa/ccc'重写为'/aaa/ccc'
                    '^/api': '',
                }
            },
        }
    }
}

其中 host 默认为 'localhost' 当声明为 '0.0.0.0' 时,就说明可以通过 内网地址 或 外网地址 都可以访问该应用。

以上是我个人的理解,vue.config.js文件代码以附到下方,如有不对的地方还请大佬斧正。

参考 配置参考 | Vue CLI🛠️ Vue.js 开发的标准工具https://cli.vuejs.org/zh/config/#vue-config-js

vue.config.js文件:

// 包含选项的对象
module.exports = {
    // 默认静态资源路径 (可添加相对路径) 需要区分 生产环境 和 开发环境
    publicPath: process.env.NODE_ENV === "production" ? "/dist/" : "/",
    // build的输出目录 默认为'dist'
    outputDir: "dist",
    // 放置静态资源的目录
    assetsDir: "static",
    // 是否每次保存进行代码检测
    lintOnSave: process.env.NODE_ENV === 'development',
    // 如果你不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。
    productionSourceMap: false,
    devServer: {
        open: true,                 // 启动后自动打开默认浏览器
        host: '0.0.0.0',            // 启动时使用的域名
        port: 8080,                 // 指定端口号
        https: false,               // 是否使用https协议
        hotOnly: false,             // 是否打开热更新
        disableHostCheck: true,     // 是否关闭HOST检查, 关闭后可以接受来自任何HOST的请求
        proxy: {
            '/api': {
            // '/api' 的意义在于,声明axios中url已/api开头的请求都适用于该规则,
            // 注意是以/api开头,即:axios.post({url: '/api/xxx/xxx'})
                // 目标服务器地址
                target: '',
                // 代理websockets
                ws: true,
                // 开启代理 (允许跨域)
                changeOrigin: true,
                pathRewrite: {
                    //重写路径 比如'/api/aaa/ccc'重写为'/aaa/ccc'
                    '^/api': '',
                }
            },
        }
    }
}

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: vue-cli3 vue.config.js 文件用于配置项目的 webpack 构建环境。可以在该文件进行如下配置: - 修改 webpack 的配置项 - 配置 devServer - 配置代理 - 使用插件 示例: ``` module.exports = { devServer: { port: 8080, proxy: { '/api': { target: 'http://localhost:3000', changeOrigin: true } } }, configureWebpack: { plugins: [ new MyAwesomeWebpackPlugin() ] } } ``` 其configureWebpack 配置项可以修改 webpack 的配置项,devServer 配置项可以配置开发服务器的相关选项,proxy 配置项可以配置代理。 注意:vue.config.js 文件不是必须的,如果项目没有该文件,则使用默认配置。 ### 回答2: Vue CLI 3是Vue.js的一个脚手架工具,用于快速构建Vue项目。vue.config.js是一个配置文件,它在项目构建过程被调用,用于配置Webpack和Vue CLI的一些选项。 vue.config.js配置文件可以设置很多选项,包括开发时代理、打包时的压缩和代码分割等等。下面是一些常用的选项: 1. publicPath publicPath是一个字符串,用于指定打包后的静态资源的路径。可以是相对路径或绝对路径,它的值会被Webpack在生成代码时加入到各个静态资源引用的URL。 2. outputDir outputDir是一个字符串,用于指定打包后的输出目录。默认值是"dist"。 3. devServer devServer是一个对象,用于配置开发服务器。其包括代理、端口号和自动打开浏览器等选项。可以用它来配置前后端联调、Mock服务等。 4. chainWebpack chainWebpack是一个函数,用于修改Webpack的配置。可以在其添加、删除、修改各种Webpack配置项。举个例子,我们可以通过chainWebpack来关闭ESLint验证: ``` chainWebpack: config => { config.module .rule('eslint') .use('eslint-loader') .tap(options => { options.emitWarning = false return options }) } ``` 5. configureWebpack configureWebpack是一个对象或函数,用于向Webpack配置添加内容。其包括Entry和Output等选项。 6. optimization optimization是一个对象,用于配置打包时的优化选项,比如代码压缩等。 7. css css是一个对象,用于配置CSS的选项。其包括分离CSS、压缩CSS、CSS的sourceMap等。 8. pluginOptions pluginOptions是一个对象,用于配置Vue CLI插件的选项。其包括ESLint、Stylelint、PWA等。我们可以通过它来关闭ESLint验证: ``` pluginOptions: { eslint: { enable: false } } ``` 除了上面提到的常用选项,vue.config.js还有很多其他配置项可供选择,具体可参考Vue CLI的官方文档。总的来说,vue.config.js是一个非常强大的工具,可以大大提高开发效率和优化打包结果。 ### 回答3: Vue.js是目前非常流行的前端框架之一,它的灵活性和易用性受到了广大开发者的欢迎。其最新的版本Vue-cli3,提供了更加方便快捷的开发模式,同时其强大的配置功能也是特别值得注意的。Vue-cli3vue.config.js文件包含着许多重要的配置选项,下面我们来逐一介绍一下。 1. publicPath publicPath选项可以指定发布路径,通过配置publicPath选项,可以将Vue应用的资源文件发布到指定的位置,这样就方便我们在多个环境部署Vue应用。例如,如果希望将Vue应用文件发布到“/my-app/”目录下,配置publicPath选项为“/my-app/”即可。 2. outputDir outputDir选项用于指定Vue应用的输出目录,通过配置outputDir选项,可以将Vue应用打包生成的文件输出到指定的目录下面。例如,如果希望将生成的文件输出到“/dist/”目录下,那么可以在vue.config.js文件配置outputDir选项为“dist”。 3. devServer devServer选项用于配置开发服务器,对于Vue应用的开发来说,它非常重要。通过配置devServer选项,可以定制开发服务器的端口、代理等信息,使我们在开发Vue应用时能够更加方便地进行调试和测试。 4. lintOnSave lintOnSave选项用于在保存代码时自动检查语法错误和格式错误,让我们在开发过程能够更加精细地把控代码质量。通过配置该选项,可以将Vue应用的代码自动规范,并保持统一的风格。 5. chainWebpack chainWebpack选项用于定制Webpack的配置,它可以让我们更加灵活地定制Vue应用的构建过程。通过配置该选项,可以添加自定义的Webpack插件,优化打包生成的文件等。 总之,Vue-cli3vue.config.js文件不仅提供了强大的配置功能,而且能够让我们更加方便地开发和部署Vue应用。掌握这些配置选项,能够让我们更加高效地进行Vue应用的开发和维护工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值