Vue 配置代理详情

 更新时间:2022年04月15日 10:43:02   作者:Errol_King  
这篇文章主要介绍了Vue 配置代理详情,文章围绕主题的相关资料展开详细内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你的学习有所帮助

方式一

首先安装 axios:npm i axios

修改 App.vue

<template>
  <div>
    <button @click="getBookInfo">获取书籍信息</button>
  </div>
</template>

<script>
import axios from "axios"
export default {
  name: 'App',
  methods:{
    getBookInfo(){
      axios.get("http://localhost:8080/downloads/data.json").then(
          response =>{
            console.log("请求成功了",response.data);
          },
          error => {"请求失败了",error.message}
      )
    }
  }
}
</script>

点击按钮请求书籍的信息,其中http://localhost:8080/downloads/data.json返回了书籍信息:

当我们点击按钮时,却发现报错了:

这是跨域请求的错误,当协议名(http)、主机名(localhost)、端口号(8080) 中有一个不一致会提示跨域请求。解决办法有:1、cors;2、jsonp;3、代理服务器

我们来学习第三个,可以先查看下官方文档 Vue Cli 配置参考:devServer.proxy

流程:8081 向 8080 请求数据,我们开启一个代理服务器,端口号和我们的 8081 相同

修改:

1、 vue.config.js,直接复制官网代码,修改端口号为请求数据的端口8080

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  lintOnSave:false,
  //开启代理服务器
  devServer: {
    proxy: 'http://localhost:8080'
  }
})

2、请求数据端口修改为本地端口 8081

3、由于修改了脚手架配置,所以先停掉端口,然后重新运行

可以看到请求成功了

方式二

方式一有两个不完美的地方:1、只能配置一个代理服务器。2、当本地也就是 public 有相同数据,就不请求代理服务器了

1、修改 vue.config.js,注释掉方式一的代码,改为

devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        pathRewrite:{'^/api':''},
        ws: true,
        changeOrigin: true
      }
    }
  }

2、请求路径增加前缀

3、由于修改了脚手架配置,所以先停掉端口,然后重新运行

vue 脚手架配置代理总结

方法一

在vue.config.js中添加如下配置:

devServer: {
    proxy: 'http://localhost:8080'
}

说明:

  • 1.优点:配置简单,请求资源时直接发给前端(8080)即可。
  • 2.缺点:不能配置多个代理,不能灵活的控制请求是否走代理
  • 3.工作方式:若按照上述配置代理,当请求了前端不存在的资源时,那么该请求会转发给服务器(优先匹配前端资源)

方法二

devServer: {
    proxy: {
      '/api': {//匹配所有以/api开头的路径
        target: 'http://localhost:8080',//代理目标的基础路径
        pathRewrite:{'^/api':''},//路径重写,匹配api开头的字符串,并把api替换为空字符串
        ws: true,//用于支持websocket
        changeOrigin: true//请求来自于。即控制请求头中host数据。默认为true说谎:来自8080;false如实回答来自代理服务器8081
      }
    }
  }

说明:

  • 1.优点:可以配置多个代理,且可以灵活的控制请求是否走代理。
  • 2.缺点:配置略微繁琐,请求资源时必须加前缀。

到此这篇关于Vue 配置代理详情的文章就介绍到这了,更多相关Vue 配置代理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vuex中Getter的用法详解

    vuex中Getter的用法详解

    这篇文章主要给大家介绍了关于Vuex中Getter的基本使用教程,getter相当于Vuex中的计算属性 对 state 做处理再返回,本文通过示例代码将Getter介绍的非常详细,需要的朋友可以参考下
    2021-07-07
  • Vue-不允许嵌套式的渲染方法

    Vue-不允许嵌套式的渲染方法

    今天小编就为大家分享一篇Vue-不允许嵌套式的渲染方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue中的this.$options.data()和this.$data用法说明

    Vue中的this.$options.data()和this.$data用法说明

    这篇文章主要介绍了Vue中的this.$options.data()和this.$data用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue监听器简单使用及注意事项说明

    Vue监听器简单使用及注意事项说明

    这篇文章主要介绍了Vue监听器简单使用及注意事项说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Vue电商网站首页内容吸顶功能实现过程

    Vue电商网站首页内容吸顶功能实现过程

    电商网站的首页内容会比较多,页面比较长,为了能让用户在滚动浏览内容的过程中都能够快速的切换到其它分类。需要分类导航一直可见,所以需要一个吸顶导航的效果。目标:完成头部组件吸顶效果的实现
    2023-04-04
  • element table 表格控件实现单选功能

    element table 表格控件实现单选功能

    本文主要介绍了element table 表格控件实现单选功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 解决Vue中mounted钩子函数获取节点高度出错问题

    解决Vue中mounted钩子函数获取节点高度出错问题

    本篇文章给大家分享了如何解决Vue中mounted钩子函数获取节点高度出错问题,对此有兴趣的朋友可以参考学习下。
    2018-05-05
  • Vue3+ElementPlus封装图片空间组件的门面实例

    Vue3+ElementPlus封装图片空间组件的门面实例

    图片空间是用于管理上传图片的工具,可以让用户方便地存储、管理和调用图片,提高工作效率,它通常具备多样的样式,但操作入口统一,便于使用,通过图片空间组件,用户能直接在其他模块(例如商品图片)中选择所需图片
    2024-09-09
  • vue脚手架及vue-router基本使用

    vue脚手架及vue-router基本使用

    这篇文章主要介绍了vue脚手架及vue-router基本使用,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-04-04
  • Vue实现按钮级权限方案

    Vue实现按钮级权限方案

    这篇文章主要介绍了Vue按钮级权限方案,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-11-11

最新评论