原来这才是学习axios的正确姿势(安装、使用、跨域代理一站式解决)

简介: Axios 是一个基于 promise 的 异步 ajax 请求库,前端最流行的 ajax 请求库。简单的讲就是可以发送get、post请求,负责与后端交互。

前言


Axios 是一个基于 promise 的 异步 ajax 请求库,前端最流行的 ajax 请求库。简单的讲就是可以发送get、post请求,负责与后端交互。


Vue、React等框架的出现,促使了Axios轻量级库的出现, react/vue 官方都推荐使用 axios 发 ajax 请求。

因为Vue等,不需要操作Dom,所以不需要引入Jquery.js了



一、安装并使用axios


1.安装


一共三种方式,分别为npm、bower和js引入方式,前两种是在终端中进行install,后者是直接利用axios的url引入来进行使用。


npm方式

npm install axios


bower方式

bower install axios


引入方式

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>


2.使用方式


首先要先在main.js里面配置axios

import Vue from 'vue'
import App from './App.vue'
import axios from 'axios'
Vue.config.productionTip = false
// 全局挂载axios
Vue.prototype.$axios=axios
new Vue({
  axios,
  render: h => h(App),
}).$mount('#app')
//若本地项目调试使用
axios.defaults.baseURL = 'http://localhost:8080'; 


配置成功后即可使用get、post、delete等请求,除此之外,还可以进行并发请求。


get请求


无参get

export default{
methods:{
  query(){
  this.$axios.get('url').then(res=>{
  console.log(res)
})
}
}
}



有参get

 //请求格式类似于 http://localhost:8080/goods.json?id=1
this.$axios.get('/url',{
          params: {
                    形参:实参
                }
      }).then(res=>{
          console.log(res.data);
        },err=>{
          console.log(err);
      })



有参get(2)

this.$axios.get(`/url?形参=${实参}`).then(res=>{console.log(res)})



post

this.$axios.post('/url',{
        形参:实参
      }).then(res=>{
        console.log(res.data);
      },err=>{
        console.log(err);
      })



并发请求

 this.$axios.all([
  this.$axios.post(`/url?形参=${实参}`),
  this.$axios.get('/url')
]).then(
  this.$axios.spread((goodsRes,classifyRes)=>{
    console.log(goodsRes.data);
    console.log(classifyRes.data);
  })
)



3.使用proxy解决跨域问题


流程:在vue.config.js配置proxy代理->main.js设置BaseUrl


vue.config.js代理配置


target中放入服务端协议 域名和端口


/api的意思是它对服务器的协议域名端口进行代理


设置后在main.js中的Baseurl放入/api即可


module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        changeOrigin: true,
        pathRewrite: {
          '^/api': '' // 将 /api 替换为空字符串,这样发送请求时就不需要再加上前缀了
        }
      }
    }
  }
}


main.js代理配置


axios.defaults.baseURL = '/api';


总结


本文主要从axios库的安装、简单使用以及跨域问题解决进行梳理和展示。


相关文章
|
1月前
|
资源调度 JavaScript 前端开发
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
这篇文章是关于如何在Vue项目中使用axios进行网络请求、二次封装axios以及使用mockjs模拟响应数据的教程。
74 1
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
|
1月前
axios允许跨域cookie
axios允许跨域cookie
30 3
|
2月前
|
JavaScript
vue 中 axios 的安装及使用
本文介绍了在Vue项目中安装和使用axios的方法。首先通过命令`npm install axios --save-dev`安装axios,然后在组件的`created`生命周期钩子中使用`axios.get`异步获取数据,并将获取的数据更新到组件的`data`中。文中提供了完整的示例代码,包括安装命令、验证安装成功的步骤、Vue组件的模板、脚本和样式。
vue 中 axios 的安装及使用
|
4月前
|
XML 前端开发 JavaScript
JavaEE:http请求 | 过滤器 | 同步与异步请求 | 跨域问题 | axios框架 有这一篇就够!
JavaEE:http请求 | 过滤器 | 同步与异步请求 | 跨域问题 | axios框架 有这一篇就够!
|
4月前
|
JSON JavaScript 前端开发
Vue中的axios深度探索:从基础安装到高级功能应用的全面指南
在Vue项目中,高效的前后端通信是构建丰富用户体验的关键。axios作为前端与后端沟通的桥梁,其重要性不言而喻。本文将带您领略axios的魅力,从基本概念、安装方法,到高级应用技巧,助您快速掌握在Vue中利用axios进行HTTP请求的精髓。我们不仅会探讨axios的基础用法,如GET、POST请求,还将深入探索跨域配置、全局注册以及设置拦截器等高级功能,助您轻松实现优雅的前后端通信。
|
11月前
Axios 通过a标签下载文件 跨域下载
Axios 通过a标签下载文件 跨域下载
Axios 通过a标签下载文件 跨域下载
|
5月前
|
JavaScript 前端开发 Linux
axios的安装和引用
axios的安装和引用
279 0
|
6月前
|
前端开发 Java Spring
axios跨域请求解决,使用注解解决
axios跨域请求解决,使用注解解决
|
6月前
|
前端开发 应用服务中间件 nginx
Vue+SpringBoot+Axios的跨域问题
Vue+SpringBoot+Axios的跨域问题
50 0
|
6月前
Vue3 配置代理和使用全局axios请求数据
Vue3 配置代理和使用全局axios请求数据
665 1

热门文章

最新文章

  • 1
    若依修改,若依如何发送请求---王清江07,axios的请求在request.js文件中,若依发送GET请求,必须用param
    116
  • 2
    axios发送post请求,如何接受和返回一个axios的字段,解决bug的方法,困难的事情先从简单做起,先从发送一个axios的post请求做起,解决方法查别人的资料,查看F12看network就行
    39
  • 3
    文本,前后端数据交互,简单请求,如何去给data数据赋值,在mounted()里赋值,利用axios发送的请求,res就是数据集,就是后端的数据,this.users = res.data.data
    44
  • 4
    Request failed with status code 400,使用axios.post要发送参数,认真比对原项目,看看有没有忘记什么?
    83
  • 5
    vue3 在 watchEffect 里中断未完成的 axios 请求(只保留最后一次请求的方法---连续点击查询按钮的优化)
    112
  • 6
    前后端数据交互.js文件的axios的写法,想要往后端发送数据,页面注入API,await的意思是同步等待服务器数据,并返回,axios注入在其他页面,其他页面调用的时候,同步作用
    42
  • 7
    前后端数据交互,API风格组合式API和选项式API,setup是一个标识,组合式编写的意思,使定义count.value的值自增的写法,组合式API使用axios的写法,ref定义响应数据写法
    27
  • 8
    网页设计,若依项目修改(It must be done)02------axios封装后发get请求,axios请求的位置在呢?
    43
  • 9
    前后端数据交互之axios的路径怎样找?axios的路径是那个,是你打开Tomcat之后,出现的路径+你项目写的接口路径
    33
  • 10
    数据交互,前后端数据请求,axios请求,对象结构的使用,E6的使用,结构赋值是什么?函数形参的obj如何,函数形参的obj就改成对象结构接收传入的数据对象
    24