vue系列教程-14axios的使用

本内容为系列内容,全部内容请看我的vue教程分类

什么是Axios

  • 是一个基于promise(承诺)的HTTP网络请求库
  • 可以用于浏览器和node.js项目
  • vue官方推荐的请求库,从以前的vue-resourceaxios

通俗点说就是对JavaScripthttp请求的二次封装,就类似jQueryajax

中文文档立即查看

原则上学习这一节需要mock数据相关的知识,但是鉴于大家都是初学者,所以不使用mock的方式,但是大家感兴趣的可以去搜索一下mock的教程,实际开发中也是常用的

安装和使用

这里我们使用前面创建的 vueclidemo这个项目,也可以你自己重新创建一个脚手架项目

npm i axios

使用 npm run serve将项目运行起来

来到Helloworld这个组件里面,删除掉不用的东西

image-20200427175821394

请求方式

  • get请求 获取数据
  • post请求 提交数据
  • put请求 更新数据
  • patch请求 更新部分数据
  • delete请求 删除数据

mock数据

真实开发是先沟通制定好api接口文档,那么我们这里先自己 mock 一个假数据,这一部分也是开发中常用的点,感兴趣的朋友可以搜索一下 mock 相关的教程

我在当前项目创建了一个mock文件夹,里面是一个模拟后台的代码,使用express进行编写,考虑到初学前端的朋友不了解,直接运行项目就行了,具体代码和本节没有关系

命令行来到 mock 文件夹,首先需要npm install下载依赖,执行node命令即可运行项目

image-20200429111946065

浏览器打开查看是否运行成功

image-20200429114804279

api文档

路径 请求类型 参数
/get get
/post post json 格式user对象
/postformdata post formdata格式user对象
/put put user对象
/del delete name 字符串
/sexlist get

引入axios

然后我们在helloworld组件的 script标签下中引入axios

import axios from "axios";

get请求

我们在methods中定义一个方法,并编写一个axiosget请求,params就是需要传递的参数,会被拼接到url地址中

getData() {
      axios
        .get("http://localhost:3000/get", {
          params: {
            name: "lili"
          }
        })
        .then(res => {
          console.log(res.data);
        })
        .catch(err => {
          console.log(err);
        });
    },

也可以这样写

axios({
  method: "get",
  url: "http://localhost:3000/get"
}).then(res => {
  console.log(res.data);
});

然后我们在 created生命周期调用这个方法

  created() {
    this.getData();
  }

浏览器查看一下效果,这就完成了第一个 get请求

image-20200429115533818

post请求

先定义一个表单数据,这里我们就先事先定义好就行了,实际开发是需要表单绑定收集的,我们在data中定义一个 user对象

data() {
  return {
    user: {
      name: "zhangsan",
      age: 11,
      sex: 1,
      avatar:
        "https://dss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=218375221,1552855610&fm=111&gp=0.jpg"
    }
  };
},

继续编写一个postData方法

postData() {
  axios.post("http://localhost:3000/post", this.user).then(res => {
    console.log(res);
  });
},

然后在 created 使用

this.postData();
image-20200429121249176

fromdata格式的post请求

传统的表单是使用 fromdata 进行提交的,我们来简单使用一下吧,再编写一个postDataFormData方法

postDataFormData() {
  let formdata = new FormData();
   //user对象填充到 formdata中
  for (let key in this.user) {
    formdata.append(key, this.user[key]);
  }
  axios({
    method: "post",
    data: formdata,
    url: "http://localhost:3000/postformdata"
  }).then(res => {
    if (res.data.code == 200) {
      alert("添加成功");
    }
  });
},

然后在 created 使用

this.postDataFormData();
image-20200429121837335

delete请求

再编写一个delData方法,delete传递参数有两种方式

delData() {
  axios
    .delete("http://localhost:3000/del", {
    //params 路径拼接的方式
      params: {
        name: "zhangsan"
      }
      // 请求头方式
      // data: {
      //   name: "zhangsan"
      // }
    })
    .then(res => {
      if (res.data.code == 200) {
        alert("删除成功");
      }
    });
},

调用一下

this.delData();
image-20200429122259289

put请求方式

再编写一个updateData方法

updateData() {
  axios.put("http://localhost:3000/put", this.user).then(res => {
    if (res.data.code == 200) {
      alert("更新成功");
    }
  });
},
image-20200429122241921

并发请求

顾名思义,就是同时发送多个请求,再编写一个getAllData方法

 getAllData() {
   axios
     .all([
       axios.get("http://localhost:3000/sexlist"),
       axios.get("http://localhost:3000/get")
     ])
     .then(
       axios.spread((sexRes, userRes) => {
         console.log(sexRes);
         console.log(userRes);
       })
     );
 },

然后调用一下

this.getAllData();
image-20200429122440449

取消请求

如何取消正在发送中的请求呢?编写一个cancelRequest方法

cancelRequest() {
  // 存储一个 token作为 axios请求标识符
  let tokenData = axios.CancelToken.source();
  axios
    .get("http://localhost:3000/get", {
      params: {
        name: "lili"
      },
      // 传入这个token
      cancelToken: tokenData.token
    })
    .then(res => {
      console.log(res.data);
    })
    .catch(err => {
      console.log(err);
    });
    // 取消请求
    tokenData.cancel("用户取消了操作");
}

调用一下

this.cancelRequest();
image-20200429122807587

配置

我们在进行http请求的时候是需要很多自定义的地方,比如超时时间,token等等,当然 axios给我们提供了自定义的接口

我们在components下创建一个CreateAxios.vue组件,并且在 views下的 Home.vue注册并使用这个组件

<template>
  <div class="home">
    <img alt="Vue logo" src="../assets/logo.png" />
    <HelloWorld />
    <CreateAxios />
  </div>
</template>
<script>
// @ is an alias to /src
import HelloWorld from "@/components/HelloWorld.vue";
import CreateAxios from "@/components/CreateAxios.vue";

export default {
  name: "Home",
  components: {
    HelloWorld,
    CreateAxios
  }
};
</script>

记得要注释掉刚刚HelloWorld组件里面的 created里面调用的方法,不然一会儿会一直调用

以下的这些代码我们都在 CreateAxios组件的 created 周期里面直接编写方便测试

全局默认配置

使用 axios.defaults进行配置,当然还有更多可以配置的点,详情看官方文档

//超时时间
axios.defaults.timeout = 1000;
//基础url
axios.defaults.baseURL = "";

全局的请求拦截器

拦截器顾名思义,就是需要拦截请求 加以处理,请求拦截器,就是拦截发送请求,加以处理

axios.interceptors.request.use(
  config => {
    //请求发送之前需要作什么
    config.headers = {};
  },
  err => {
    return Promise.reject(err);
  }
);

全局的响应拦截器

 axios.interceptors.response.use(
   res => {
     //对请求成功的数据处理
     return res;
   },
   err => {
     return Promise.reject(err);
   }
 );

创建实例

在实际开发当中,一般是不会全局配置,因为一个项目中的接口有很多的不同

所以我们需要创建多个实例然后进行分别的配置

创建实例

let httpRequest = axios.create();

这样我们就创建好了,接下来使用axios进行网络访问就不需要再使用axios.xxx了,而是使用 httpRequest.xxx

实例的基础配置

let httpRequest = axios.create({
  //基本url
  baseURL: "http://localhost:3000",
  //   超时时间
  timeout: 1000,
  //头文件
  Headers: {}
});

实例的请求拦截器

比如这里我们给他加上一个 token

httpRequest.interceptors.request.use(
  config => {
    config.headers.token = "xxxxxxxxxx";
    return config;
  },
  err => {
    return Promise.reject(err);
  }
);

然后再次编写一个get请求

httpRequest.get("/get").then(res => {
  console.log(res);
});

看看浏览器效果

image-20200429124950115

实例的响应拦截器

我们也可以在这个得到响应以后进行处理,比如不同的错误码给用户不同的提示

 httpRequest.interceptors.response.use(
   res => {
     return res;
   },
   err => {
     console.log("response err=>", err);
     return Promise.reject(err);
   }
 );

这样就完成了 axios 的基础使用了,实际开发中会对axios进行二次封装,这就在后面的教程里面了

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349