当前位置:首页 > 前端开发 > axios方式接口调用

axios方式接口调用

6个月前 (05-21)54

接口调用方式

  • 原生ajax

  • 基于jQuery的ajax

  • fetch

  • axios

异步理解

  • JavaScript的执行环境是「单线程」

  • 所谓单线程,是指JS引擎中负责解释和执行JavaScript代码的线程只有一个,也就是一次只能完成一项任务,这个任务执行完后才能执行下一个,它会「阻塞」其他任务。这个任务可称为主线程

  • 异步模式可以一起执行多个任务

  • JS中常见的异步调用

    • 定时任何

    • ajax

    • 事件函数

promise理解

axios基础用法

  • 基于promise用于浏览器和node.js的http客户端

  • 支持浏览器和node.js

  • 支持promise

  • 能拦截请求和响应

  • 自动转换JSON数据

  • 能转换请求和响应数据

  • get和 delete请求传递参数

    • 通过传统的url 以 ? 的形式传递参数

    • restful 形式传递参数

    • 通过params 形式传递参数

  • post 和 put 请求传递参数

    • 通过选项传递参数

    • 通过 URLSearchParams 传递参数

# 1. 发送get 请求 
    axios.get('http://localhost:3000/adata').then(function(ret){ 
      #  拿到 ret 是一个对象      所有的对象都存在 ret 的data 属性里面
      // 注意data属性是固定的用法,用于获取后台的实际数据
      // console.log(ret.data)
      console.log(ret)
    })
    # 2.  get 请求传递参数
    # 2.1  通过传统的url  以 ? 的形式传递参数
    axios.get('http://localhost:3000/axios?id=123').then(function(ret){
      console.log(ret.data)
    })
    # 2.2  restful 形式传递参数 
    axios.get('http://localhost:3000/axios/123').then(function(ret){
      console.log(ret.data)
    })
    # 2.3  通过params  形式传递参数 
    axios.get('http://localhost:3000/axios', {
      params: {
        id: 789
      }
    }).then(function(ret){
      console.log(ret.data)
    })
    #3 axios delete 请求传参     传参的形式和 get 请求一样
    axios.delete('http://localhost:3000/axios', {
      params: {
        id: 111
      }
    }).then(function(ret){
      console.log(ret.data)
    })
​
    # 4  axios 的 post 请求
    # 4.1  通过选项传递参数
    axios.post('http://localhost:3000/axios', {
      uname: 'lisi',
      pwd: 123
    }).then(function(ret){
      console.log(ret.data)
    })
    # 4.2  通过 URLSearchParams  传递参数 
    var params = new URLSearchParams();
    params.append('uname', 'zhangsan');
    params.append('pwd', '111');
    axios.post('http://localhost:3000/axios', params).then(function(ret){
      console.log(ret.data)
    })
​
    #5  axios put 请求传参   和 post 请求一样 
    axios.put('http://localhost:3000/axios/123', {
      uname: 'lisi',
      pwd: 123
    }).then(function(ret){
      console.log(ret.data)
    })
axios全局配置
#  配置公共的请求头 
axios.defaults.baseURL = 'https://api.example.com';
#  配置 超时时间
axios.defaults.timeout = 2500;
#  配置公共的请求头
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
# 配置公共的 post 的 Content-Type
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

axios拦截

  • 请求拦截器

    • 请求拦截器的作用是在请求发送前进行一些操作

      • 例如在每个请求体里加上token,统一做了处理如果以后要改也非常容易

  • 响应拦截器

    • 响应拦截器的作用是在接收到响应后进行一些操作

      • 例如在服务器返回登录状态失效,需要重新登录的时候,跳转到登录页

 # 1. 请求拦截器 
    axios.interceptors.request.use(function(config) {
      console.log(config.url)
      # 1.1  任何请求都会经过这一步   在发送请求之前做些什么   
      config.headers.mytoken = 'nihao';
      # 1.2  这里一定要return   否则配置不成功  
      return config;
    }, function(err){
       #1.3 对请求错误做点什么    
      console.log(err)
    })
    #2. 响应拦截器 
    axios.interceptors.response.use(function(res) {
      #2.1  在接收响应做些什么  
      var data = res.data;
      return data;
    }, function(err){
      #2.2 对响应错误做点什么  
      console.log(err)
    })

async 和 await

  • async作为一个关键字放到函数前面

    • 任何一个async函数都会隐式返回一个promise

  • await关键字只能在使用async定义的函数中使用

    • await后面可以直接跟一个 Promise实例对象

    • await函数不能单独使用

  • async/await 让异步代码看起来、表现起来更像同步代码

# 1.  async 基础用法
    # 1.1 async作为一个关键字放到函数前面
    async function queryData() {
      # 1.2 await关键字只能在使用async定义的函数中使用      await后面可以直接跟一个 Promise实例对象
      var ret = await new Promise(function(resolve, reject){
        setTimeout(function(){
          resolve('nihao')
        },1000);
      })
      // console.log(ret.data)
      return ret;
    }
    # 1.3 任何一个async函数都会隐式返回一个promise   我们可以使用then 进行链式编程
    queryData().then(function(data){
      console.log(data)
    })
​
    #2.  async    函数处理多个异步函数
    axios.defaults.baseURL = 'http://localhost:3000';
​
    async function queryData() {
      # 2.1  添加await之后 当前的await 返回结果之后才会执行后面的代码   
      
      var info = await axios.get('async1');
      #2.2  让异步代码看起来、表现起来更像同步代码
      var ret = await axios.get('async2?info=' + info.data);
      return ret.data;
    }
​
    queryData().then(function(data){
      console.log(data)
    })

.

作者:鞋破露脚尖儿
来源链接:https://www.cnblogs.com/msi-chen/p/12713414.html

标签: Axios

“axios方式接口调用” 的相关文章

爬坑日记 1.axios请求参数为数组时报错

在请求接口的时候,要传递的参数为一个数组。但是其真实传递的却不是一个数组,例如: 传递的参数数组为 userId = [0,1,2] 但真实的请求头的参数是,它会在变量名的后面加个[]:...

Axios拦截器

Axios拦截器

  interceptors   如果我们想在请求之前做点什么,用拦截器再好不过了   拦截器一般做什么?     1. 修改请求头的一些配置项     2. 给...

vue axios用法

axios axios 是基于promise的用于浏览器和nodejs的HTTP客户端 特征: 从浏览器中创建XMLHttpRequest 从node...

Axios笔记

axios笔记 基本知识 axios返回的是一个promise对象 axios将服务器返回结果自动json解析变成对象形式 请求拦截器和响应拦截器 请求拦截...

AXIOS源代码重点难点分析

摘要 vue使用axios进行http通讯,类似jquery/ajax的作用,类似angular http的作用,axios功能强大,使用方便,是一个优秀的htt...

axios 学习笔记

axios请求方法:get、post、put、patch、delete get:获取数据 post:提交数据(表单提交+文件上传) put:更新数据(所有数据推送到后端...

vue-axios

安装依赖 npm i axios 在main.js文件中声明 import axios from 'axios' Vue.prototyp...

axios面试题

谈谈你对axios的理解? axios是基于XMLHttpRequest服务来执行HTTP请求,支持Promise。 它可以拦截请求和响应 可以转换请求数据和响应数据,...

axios基本使用

axios的基本方法post&get,以及动态处理headers中的参数,以及相关Axios.js、Qs.js相关JS文件 axios相关使用 一、axi...

HTTP库Axios

HTTP库Axios

[1]概述 [2]使用 [3]API [4]实例方法 [5]响应结构 [6]配置默认值 [7]拦截器 [8]错误处理 [9]取消 前面的话   本文将详细介绍HT...