IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 第 8 节 axios -> 正文阅读

[JavaScript知识库]第 8 节 axios

jsonp

axios

定义:axios就是一种 前端向后端发送网络请求 的工具。
功能特点:
(1)在浏览器中发送 XMLHttpRequests 请求
(2)在node.js 中发送 http 请求
(3)支持 Promise API
(4)拦截请求和响应
(5)转换请求和响应数据,等等

axios框架的基本使用

// 1.没有请求参数
axios({
  url: 'http://123.207.32.32:8000/home/multidata',

  // axios(),默认是get请求,可以通过method来设置请求方式
  // method: 'post'

}).then(res => {
  // 在then里面拿到想要的结果
  console.log(res);
})

// 2.有请求参数
axios({
  url: 'http://123.207.32.32:8000/home/data',
  //专门针对get请求的参数拼接
  params: {
    type: 'pop',
    page: 1
  }
}).then(res => {
  console.log(res);
})

axios发送并发请求

axios的相关配置

注: 不同请求,传入的对象需要对应
(1)get请求,传入params
(2)post请求,传入data

axios的实例和模块封装

axios的实例

前面均是使用 全局的 axios和对应的配置在进行网络请求。

// 创建对应的axios的实例
const instance1 = axios.create({
  baseURL: 'http://123.207.32.32:8000',
  timeout: 5000
})

instance1({
  url: '/home/multidata'
}).then(res => {
  console.log(res);
})

instance1({
  url: '/home/data',
  params: {
    type: 'sell',
    page: 2
  }
}).then(res => {
  console.log(res);
})

模块封装

模块封装 就是为了能够在项目中,不要直接使用第三方框架
在封装好的模块中使用第三方框架,而其他的网络请求仅向封装好的模块进行交互,可以有效避免当第三方框架被废弃时,程序需要做大规模改动。

axios的拦截器

request.js文件中的代码

import axios from 'axios'

export function request(config) {
  // 1.创建axios的实例
  const instance = axios.create({
    baseURL: 'http://123.207.32.32:8000',
    timeout: 5000
  })

  // 2.axios的拦截器
  //2.1 请求拦截
  axios.interceptors.request.use(config => {
    // console.log(config);
    //1.比如config中的一些信息不符合服务器的要求

    //2.比如每次发送网络请求时,都希望在界面中显示一个请求的图标

    //3.某些网络请求(比如登录(token)),必须携带一些特殊的信息

    return config
  }, err => {
    // console.log(err);
  })


  // 2.2 响应拦截
  instance.interceptors.response.use(res => {
    // console.log(res);
    return res
  }, err => {
    // console.log(err);
  })


  //3.发送真正的网络请求
  //instance返回的就是一个Promise
  return instance(config)
}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-16 18:44:30  更:2021-11-16 18:44:32 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 3:56:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码