vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > vue ajax请求跨域

如何通过Vue自带服务器实现Ajax请求跨域(vue-cli)

作者:南瓜骨头

从A页面访问到B页面,并且要获取到B页面上的数据,而两个页面所在的端口、协议和域名中哪怕有一个不对等,那么这种行为就叫跨域,这篇文章给大家介绍如何通过Vue自带服务器实现Ajax请求跨域(vue-cli),感兴趣的朋友一起看看吧

通过Vue自带服务器实现Ajax请求跨域(vue-cli)

跨域

为什么端口、协议和域名有一个不同就不能跨域?

实现方案(需要安装axios)

在这里插入图片描述

安装axios

启动Vue内置服务器8080的代理功能,在vue.config.js中进行配置

第一种:简单开启

// vue.config.js文件
devServer : {
    // Vue内置服务器8080端口
    proxy : 'http://localhost:8000'
}
// XXX.vue文件
axios.get('/请求路径').then(
    response => {
        // response.data:响应数据信息
        console.log('响应数据', response.data);
    },
    error => {
        // error.message:出现错误时,显示错误信息
        console.log('错误信息', error.message);
    }
)

第二种:高级开启(常用)

devServer : {
    proxy : {
      // 凡事请求路径以/api开始的,都走这个代理
      '/api' : {
        // 端口路径
        target : 'http://localhost:8000',
        // 重写'/api'路径
        pathRewrite : {'^/api':''},
        // 默认值true:表示支持 websocket
        ws : true,
        // 默认值true:表示改变起源(让目标服务器不知道真正的起源)
        changeOrigin : true
      },
      '/foo' : {
        target : '<other_url>'
      }
    }
  }
// XXX.vue文件
axios.get('(如果没设置pathRewrite的话,这里是要加上/api的)/请求路径').then(
    response => {
        // response.data:响应数据信息
        console.log('响应数据', response.data);
    },
    error => {
        // error.message:出现错误时,显示错误信息
        console.log('错误信息', error.message);
    }
)

到此这篇关于通过Vue自带服务器实现Ajax请求跨域(vue-cli)的文章就介绍到这了,更多相关vue ajax请求跨域内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文