代码编织梦想

网络请求库axios

axios官网

  • 功能特点
    • 在浏览器中发送 XMLHttpRequests请求
    • 在node.js中发送http请求
    • 支持Promise API
    • 拦截请求和响应
    • 转换请求和响应数据

axios请求方式

  • 支持多种请求方式

    axios(config)

    axios.request(config)

    axios.get(url[, config])

    axios.delete(url[, config])

    axios.head(url[, config])

    axios.options(url[, config])

    axios.post(url[, data[, config]])

    axios.put(url[, data[, config]])

    axios.patch(url[, data[, config]])

    axios.postForm(url[, data[, config]])

    axios.putForm(url[, data[, config]])

    axios.patchForm(url[, data[, config]])

  • 常见的 config配置选项

    • 请求地址(url:‘/user’
    • 请求类型(method:‘get’
    • 请求根路径(baseURL:‘http://www.xxx.com’
    • 请求前的数据处理(transformRequest:[function(data){}]
    • 请求后的数据处理(transformResponse:[function(data){}]
    • 自定义的请求头(headers:{‘x-Requested-With’:‘XMLHttpRequest’}
    • URL查询对象(params:{id:12}

基本使用

  • 通过 npm install axios进行安装

  • 在main.js中引入axios

import axios from "axios";
  • 使用 axios.request(config)发送网络请求,默认是get方法
axios.request("http://xxxxx").then((res) => {
  console.log(res.data);
});
  • 使用 axios.get(url[, config])发送网络请求
//第一种写法,把query直接写在url中
axios.get("http://xxxx?id=500665346").then((res) => {
    console.log(res.data);
});

//第二种写法,通过config写query
axios
    .get("http://xxxx", {
    params: {
        id: 500665346,
    },
})
    .then((res) => {
    console.log(res.data);
});
  • 使用 axios.post(url[, data[, config]])发送网络请求
//第二个参数可以直接传请求对象
axios
  .post("http://xxxxx", {
    username: "admin",
    password: "123456",
  })
  .then((res) => {
    console.log(res.data);
  });
//第二个参数可以传config对象,post请求对象需要用data包裹

axios
  .post("http://xxxx", {
    data: {
      username: "admin",
      password: "123456",
    },
  })
  .then((res) => {
    console.log(res.data);
  });

baseURL

针对于项目中的多个网络请求,我们每次写网络请求的host会显得十分麻烦,因此可以借助baseURL进行简化

  • 通过 axios.defaults.baseURL进行设置
import axios from "axios"

const baseURL = "http://xxxx"
axios.defaults.baseURL = baseURL
axios.defaults.timeout = 1000

axios.get("/home").then((res)=>{
    console.log("res",res.data)
})

axios.all发送多个请求

  • axios.all中传入一个数组,当都有结果的时候,才会调用then方法
  • 实际上在axios的内部,就是调用了promise.all方法
axios.all([
    axios.get("http://xxxx"),
    axios.get("http://xxx")
]).then((res)=>{
    console.log(res)
})

axios的创建实例

  • 在上面的例子中,我们通过import引入的默认实例发送的网络请求
import axios from "axios"
axios.get()...
  • 但是在实际的项目开发中,有可能数据从多个不同的服务器中获取

  • 因此我们可以通过axios创建不同的实例

import axios from "axios"

const instance = axios.create({
    baseURL:"http://123.456.789"
})

const instance = axios.create({
    baseURL:"http://456.789.123"
})


//通过创建的实例发送网络请求
instance.get()
instance.get()

请求和响应的拦截

  • 通过 axios.interceptors.request/response对请求和响应进行拦截
// axios.interceptors.request.use(成功的回调,失败的回调)
axios.interceptors.request.use(
  (config) => {
    //会将请求的配置传入
    //1.开始loading动画
    //2.对原来的配置进行修改
    //2.1header
    //2.2认证登录:token/cookie
    //请求参数的某些转化
    console.log("请求成功");
    return config;
  },
  (err) => {
    console.log("请求失败了");
    return err;
  }
);

// axios.interceptors.response.use(成功的回调,失败的回调)
axios.interceptors.response.use(
  (res) => {
    console.log("响应成功");
    //return之后的数据,会在请求后的.then中接收到
    return res.data;
  },
  (err) => {
    console.log("请求失败");
    return err;
  }
);

axios
  .get("http://123.207.32.32:8000/home/multidata")
  .then((res) => {
    console.log(res);
  })
  .catch((err) => {
    console.log(err);
  });
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_55041125/article/details/136137849

vue cli3的http请求封装_「已注销」的博客-爱代码爱编程_vue3 封装http

import Cookies from 'js-cookie' const TokenKey = 'access_token' const contractNo = 'contractNo' export functio

vue3.0解决跨域问题Access to XMLHttpRequest at ___has been blocked by CORS policy: No ‘Access-Control-Allow-爱代码爱编程

1,vue3.0根目录下创建vue.config.js文件 2,将代码块写入其中 module.exports = { devServer: { proxy: { '/api': { target: 'https://blog.csdn.net/', //接口域名(你请求的

Vue3.0项目框架搭建之四:axios网络请求、拦截器封装-爱代码爱编程

上一章我们引入了elementui库以后,整个项目已经可以开始前端页面的开发了。但是,基于现在前后分离架构的原因,我们需要调用后台接口来获取页面展示的数据。 关于网络请求使用的方法有很多,比较推荐的就是 axios。官方介绍说支持node,可能在以后使用nodejs做服务开发的时候,也能用到。 安装 npm install axios 在api文

vue3实战笔记(52)—vue 3封装持仓分析饼图-爱代码爱编程

文章目录 前言一、封装持仓分析饼图总结 前言 接上文,封装持仓分析饼图。 一、封装持仓分析饼图 EChartsPieBorderRadiusType.vue: <templat

书籍学习|基于sprinboot+vue的书籍学习平台(源码+数据库+文档)-爱代码爱编程

书籍学习平台 目录 基于SprinBoot+vue的书籍学习平台 一、前言 二、系统设计 三、系统功能设计  1平台功能模块 2后台功能模块 5.2.1管理员功能模块 5.2.2用户功能模块 5.2.3作者功能模块 四、数据库设计  五、核心代码  六、论文参考 七、最新计算机毕设选题推荐 八、源码获取:

vue3 vue-爱代码爱编程

一、vue3 vue-draggable-next 实现拖拽穿梭框效果 <template> <div> <h2>列表 1</h2> <

elemnt ui 时间选择器。 当前日期往前推6个月以前的的不可选择-爱代码爱编程

<div class="hengxiang"> <div class="lefttitle titlesBt" style="color:#15a66a;">