vue.config.js

vue.config.js相关的知识信息
一,vue.config.js是vue打包管理的配置文件,旨在给开发者们自定义自己的配置

1,该文件的根式统一,为导出配置项选项。例如:

在这里插入图片描述

在对象里面书写我们自己的配置项目。

二,具体的配置内容(项目中常用的)

1,publicPath: “/” (这是默认值,为站点跟目录),在.html文件中,“/“ 就代表站点的根目录。

例如:配置后结果
在这里插入图片描述

例如:当配置使用默认值,就是不配置时的结果

在这里插入图片描述

当我们结合打包时的一般用法是:(根据环境的不同配置的路径不同,这个也是需要配置,具体请参考相关文档)

在这里插入图片描述
  2,outputDir(打包时输出的文档路径)默认值为”dist“

3,assetsDir(放置生成的静态资源 (js、css、img、fonts) 的 (相对于 outputDir 的) 目录)默认值为空,这个时相对于outputDir的,如果outputDir为dist,则就在dist下创建相关文件夹。

4,lintOnSave(在开发环境下通过 eslint-loader 在每次保存时 lint 代码。这个值会在 @vue/cli-plugin-eslint 被安装之后生效)

5,runtimeCompiler(默认值为false,是否使用包含运行时编译器的 Vue 构建版本。设置为 true 后你就可以在 Vue 组件中使用 template选项了,但是这会让你的应用额外增加 10kb 左右)

6,devServer(值为对象,配置开发环境的服务器配置,例如:host,port,https等)

在这里插入图片描述

7,devServer.proxy(是第6项的子配置,配置代理服务器,值可以是对象,也可以是字符串;如果你的前端应用和后端 API 服务器没有运行在同一个主机上,你需要在开发环境下将 API 请求代理到 API 服务器)

devServer.proxy 的详解

我们最终的请求地址:http://47.107.135.218/api/index.php

首先我们的请求:
在这里插入图片描述

配置代理:

在这里插入图片描述

原理剖析:当我们访问的url路径中含有 “/apiavatardatacn” 字符传的时候,与配置的代理有关联字段。

1,如果配置的 pathRewrite:{ } 对象,如上图所示,就会将 “/apiavatardatacn/api/index.php” 路径重写为 “http://47.107.135.218/api/index.php” 意思就是,/apiavatardatacn 的字符串置空,然后又targe的值替换。

2,如果没有配置 pathRewrite:{ } 对象,如下图,就会将 “/apiavatardatacn/api/index.php” 路径重写为 “http://47.107.135.218/apiavatardatacn/api/index.php”,显然此时的 “/apiavatardatacn”就是多余的。

所以以上就是 pathRewrite 配置与否的作用
在这里插入图片描述

二、PROXY中跨域中PATHREWRITE配置理解

  1. vue本地项目调试线上接口出现跨域问题
  2. 通过在 config/index.js 配置文件中找到proxyTable配置项
dev: {

    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      '/api': {
        target: 'http://XX.XX.XX.XX:8083',
        changeOrigin: true,
        pathRewrite: {
          '^/api': '/api'   // 这种接口配置出来实际请求     http://XX.XX.XX.XX:8083/api/login
          //'^/api': '/' 这种接口配置出来实际请求 http://XX.XX.XX.XX:8083/login
        }
      }
    }
  },
  1. 配置完成后需要重新编译一遍 , 调用接口的时候
 // 获取菜单权限
      getPermission(){
        this.$ajaxget({
          url: '/api/getPermission',
          data: {},
          isLayer: true,
          successFc: data => {
            console.log(data.data)
          }
        })
      },
      ```
4 . 因为我的项目接口中 是存在 ‘/api’ 这个字段的 所以我选择的是第一种配置

图解
![在这里插入图片描述](https://img-blog.csdnimg.cn/7059cd5348c24649a057c6e12811ec2f.png)

效果图:
![在这里插入图片描述](https://img-blog.csdnimg.cn/bd46487ec756409f85f1ca921b304fc8.png)


![在这里插入图片描述](https://img-blog.csdnimg.cn/3236a756419840a7a2ba8ec660859df3.png)

效果图:
![在这里插入图片描述](https://img-blog.csdnimg.cn/63756c4df14949a991b8e3c77ddfd7f2.png)

VUE----设置路径别名

在项目中有时我们使用相对路径引入文件时由于路径太长会很不方便,这个时候我们可以设置路径别名

1.项目根目录下创建vue.config.js文件:
2.下载扩展包:

npm install path --save
常用函数:
         1、path.dirname()  :获取目录
         2、path.basename() :获取文件名.扩展名(我们统称为全名)
         3、path.extname()  : 获取扩展名
         4、path.parse()    : 将一个路径转换成一个js对象
         5、path.format()   :将一个js对象转换成路径
         6、join()          : 拼接多个路径成一个路径
         7、path.resolve() :将相对路径转为绝对路径
常用变量:
         1.__dirname: **总是返回被执行的 js 所在文件夹的绝对路径**
         2.__filename: 总是返回被执行的 js 的绝对路径

在这里插入图片描述

3.编辑vue.config.js文件:

1.引入path:
    const path = require('path');
2.封装方法:
    function resolve(dir){
        return path.resolve(__dirname,dir)
    }
3.配置文件:
module.exports = {
  configureWebpack:{
    resolve: {
          alias: {
            'src': resolve('src'),
              'assets': resolve('src/assets'),
              'images': resolve('src/assets/images')
          }
        }
  }
}

4.重新编译:
注意:修改vue.config.js必须重新编译项目,否则配置不生效

npm run serve

5.组件中引用:
在组件中使用~加路径别名的方法引用

示例代码:
  <template>
    <div id="app">
      <img src="~images/index.png">
    </div>
  </template>

6.至此,路径别名的基本设置就完成了

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值