篇章六 网络请求模块选择——axios

上一篇:【Vuejs进阶版

一、为什么选择 axios?

axios = ajax i/o system

  • 在浏览器中发送 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.post(url[,data[,[,config]]))
  • axios.put(url[,data[,config]])
  • axios.patch(url[,data[,config]])

二、axios框架的基本使用

  1. vue init webpack learnaxios:创建vue项目
  2. npm install axios@0.18.0 --save:安装axios【cd到相关目录下】
  3. import导入
    在这里插入图片描述

三、axios发送并发请求

1、发送 get 请求演示:

在这里插入图片描述

2、发送两个请求并发执行

  • 第一种方法:使用axios.all,可以存放多个数组
    在这里插入图片描述
  • 第二种方法:axios.all([])返回的结果是一个数组,使用axios.spread可将数组[res1,res2]展开为 res1,res2
    在这里插入图片描述

4、全局配置

开发中,可能很多参数都是固定的,这个时候我们可以进行一些抽取,也可以利用 axios 的全局配置
在这里插入图片描述
常见的配置选项:
在这里插入图片描述

四、axios 的实例

1、为什么要创建 axios 的实例(instance)

  • 当我们从 axios 模块中导入对象时,使用的实例是默认的实例
  • 当给该实例设置一些默认配置时,这些配置就被固定下俩了
  • 但是后续开发中,某些配置可能会不太一样
  • 比如某些请求需要使用特定的 baseURL 或者 timeout 或者 content-Type 等
  • 这个时候,我们就可以创建新的实例,并且传入属于该实例的配置信息
    请添加图片描述

五、如何使用拦截器

请求成功、请求拦截
响应成功、响应拦截
在这里插入图片描述

六、axios封装和请求响应劫持

做拦截处理

1、安装axios

npm install axios --save

2、创建模拟的配置文件
新建文件:src\config\index.js

export default{
    title:"elm",
    baseUrl:{
        dev:"http://localhost:3000", //开发的时候后台接口的地址
        pro:"" // 上线产品发布之后,后台接口的地址 
    }
}

3、使用axios做ajax请求

新建文件:src\api\axios.js

import axios from 'axios'
import config from '@/config'

// 判断node的开发模式
const baseUrl = process.env.NODE_ENV ===  'developent' ? config.baseUrl.dev : config.baseUrl.pro
console.log(process.env.NODE_ENV);
class HttpRequest{
    // 配置要请求的URL地址
    constructor(baseUrl){
        this.baseUrl = baseUrl
        // 对请求队列进行处理
        this.queue={}
    }
    // 设置很多的配置
    getInsideConfig(){
         const config = {
            baseURL:this.baseUrl,
            header:{
            //  请求头的配置
            }
         }
         return config
    }
    // 做一个拦截interceptors(请求实例,url)
    interceptors(instance,url){
        // 拦截请求
        instance.interceptors.request.use((config)=>{
            // 处理config,判断是否是所有的拦截都会通过这里
            console.log('拦截和处理请求');
            console.log(config);
            return config;
        })
        // 拦截响应
        instance.interceptors.reponse.use((res)=>{
            // 处理响应
            console.log('处理响应');
            console.log(res);
            return res.data;
        },(error)=>{
            // 请求出问题,处理问题
            console.log(error);
            return {
                error:"网络出错了"
            }
        })
    }
    request(options){
        const instance = axios.create() //创造实例对象
        // 与上文getInsideConfig()形成呼应,options会覆盖掉this.getInsideConfig
        options = Object.assign(this.getInsideConfig(),options)
        // 进行数据劫持
        this.interceptors(instance,options.url)
        return instance(options)
    }

}
// 实例化拦截对象
const axiosObj = new HttpRequest(baseUrl)
// 导出
export default axiosObj

新建文件:src\api\data.js

// 对外做ajax请求
import axios from '@/api/axios'

export const getBannerData = ()=>{
    return axios.request({
        url:"banner",
        methods: 'get'
    })
}

测试:

views\Home.vue文件中

<template>
  <div class="home">
    <h1>HOME</h1>
  </div>
</template>

<script>
// @ is an alias to /src
import HelloWorld from '@/components/HelloWorld.vue'
import {getBannerData} from '@/api/data'

export default {
  name: 'Home',
  components: {
    HelloWorld
  },
  async mounted(){
    let result = await getBannerData()
    console.log(result);
  }
}
</script>

运行elm项目:npm run serve
模拟编写后端数据,供前端使用
elm同级新建elmserve/index.js文件,内容如下:

let express = require('express')
let app = express()

// 解决跨域问题
app.use((req,res,next)=>{
    res.append('Access-Control-Allow-Origin','*')
    res.append('Access-Control-Allow-headers','*')
    next()
})

app.get('/',(req,res)=>{
    res.json({
        msg:"这是首页"
    })
})

app.get('/banner',(req,res)=>{
    res.json({
        msg:"这是banner"
    })
})


app.listen(3000,()=>{
    console.log('http://localhost:3000');
})

下一篇:【Vue项目开发】

在Node.js中使用axios请求接口以及拦截器的使用方法如下: 首先,需要安装axios模块: ``` npm install axios ``` 然后,在代码中引入axios模块: ```js const axios = require('axios'); ``` 接下来,可以使用axios发送GET、POST等请求: ```js axios.get('http://example.com/api') .then(response => { console.log(response.data); }) .catch(error => { console.log(error); }); axios.post('http://example.com/api', {data: 'hello'}) .then(response => { console.log(response.data); }) .catch(error => { console.log(error); }); ``` 当然,axios还支持一些其他的请求方法,比如PUT、DELETE等。 接下来,我们可以使用axios的拦截器对请求和响应进行处理。例如,我们可以在请求头中添加token: ```js axios.interceptors.request.use(config => { const token = localStorage.getItem('token'); if (token) { config.headers.Authorization = `Bearer ${token}`; } return config; }, error => { return Promise.reject(error); }); ``` 在上面的代码中,我们使用了axios的interceptors.request.use方法,它可以在请求被发送出去之前对其进行拦截处理。在这个例子中,我们将localStorage中存储的token添加到请求头中的Authorization字段中。 我们还可以使用axios的interceptors.response.use方法对响应进行处理。例如,我们可以检查响应状态码是否为401,如果是,则跳转到登录页面: ```js axios.interceptors.response.use(response => { return response; }, error => { if (error.response.status === 401) { window.location.href = '/login'; } return Promise.reject(error); }); ``` 在上面的代码中,我们使用了axios的interceptors.response.use方法,它可以在响应被接收之前对其进行拦截处理。在这个例子中,我们检查了响应状态码是否为401,并且在这种情况下跳转到登录页面。 以上就是在Node.js中使用axios请求接口及拦截器的使用方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

博客zhu虎康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值