vue-网络代理

跨域前后端交互

在vue项目中,经常需要将后端数据请求到vue项目中然后拿来使用并显示到页面上,但是后端服务器与我们的vue测试服务器是不一样的,因此我们请求数据的时候,往往需要进行跨域请求,如果后端是在egg框架上写的,那么就需要给egg框架配置跨域请求,这样就可以然后配置router,以及返回数据这样就可以得到了

 

这就是在vue项目中,当组件加载完成后,就执行axios工具,进行网络请求,然后因为vue的默认端口号是8080,所以一定会造成跨域问题,但是如果egg框架配置了跨域,然后再在router里面进行对应的注册,那么就没有什么问题如:

 

 这样在controller文件和router文件中分别配置,就完成了,这时,vue主页加载完成后,就会将返回的对象打印在控制台中,这完成了vue的前后端的初步交互。

网络代理

在vue中上面这样的方式需要将egg框架配置跨域请求,这里有一种不需要跨域,就直接能获得数据的方式,那就是vue中的网络代理,

首先需要在vue.config.js中添加一个官方提供的对象proxy如:

 

 egg框架中不用变

这样也一样完成了前后端的初步交互。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用Vue-cli进行开发时,我们常常会遇到跨域的问题。为了解决这个问题,我们可以使用vue.config.js文件进行代理设置。 首先,打开项目根目录下的vue.config.js文件。 其次,我们需要在该文件中添加一个devServer选项,来进行代理的配置。具体代码如下: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://example.com', // 需要跨域的域名 changeOrigin: true, // 是否进行跨域 pathRewrite: { '^/api': '' // 将/api替换为空字符串 } } } } } ``` 其中,target指定了需要跨域请求的域名。changeOrigin设置为true表示开启跨域。pathRewrite用于重写请求地址,将/api替换为空字符串。 最后,保存文件并重新运行项目。此时,我们就成功地设置了跨域代理。 然而,有时候我们可能会遇到404错误。这通常是因为代理的地址不正确,或者目标服务器无法处理正确的路由地址。 我们需要确保target的值和实际需要跨域请求的域名一致。另外,需要确保pathRewrite中的替换规则正确。 如果以上操作仍然无法解决问题,可以参考目标服务器的接口文档,确认请求地址是否正确。同时,可以使用开发工具的网络面板查看请求的详细信息,以便进行进一步的排查。 总结:使用vue-cli进行跨域代理时,可以通过配置vue.config.js文件来解决跨域问题。如果出现404错误,需要检查配置是否正确,并确认目标服务器是否能正确处理请求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值