2024年Web前端最全【vue2】axios请求与axios拦截器的使用详解,前端高级面试视频

2024年Web前端最全【vue2】axios请求与axios拦截器的使用详解,前端高级面试视频

码农世界 2024-05-22 前端 56 次浏览 0个评论
框架相关

原生JS虽能实现绝大部分功能,但要么就是过于繁琐,要么就是存在缺陷,故绝大多数开发者都会首选框架开发方案。现阶段较热门是React、Vue两大框架,两者工作原理上存在共通点,也存在一些不同点,对于校招来说,不需要两个框架都学得特别熟,一般面试官会针对你简历中写的框架进行提问。

在框架方面,生命周期、钩子函数、虚拟DOM这些基本知识是必须要掌握的,在学习的过程可以结合框架的官方文档

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

Vue框架

知识要点:

1. vue-cli工程

2. vue核心知识点

3. vue-router

4. vuex

5. http请求

6. UI样式

7. 常用功能

8. MVVM设计模式

React框架

知识要点:

1. 基本知识

2. React 组件

3. React Redux

4. React 路由

**3.大小不同。**get写在地址栏上面,因此有长度的限制,最大长度为2k左右,而我们的post写在请求体中没有大小的限制

**4.安全性不同。**get的参数可以直接看到,post参数需要按下F12来查看


二、axios拦截器

2.1axios拦截器介绍

【授人以鱼不如授人以渔】我们通过官网出的文件来进行一个讲解:

请求拦截器:处理我们在发送请求之前需要经过的回调函数

相应拦截器:服务器响应之后返回给我们之前会被执行的回调函数

官网指南:拦截器 | Axios 中文文档 | Axios 中文网 (axios-http.cn)")

下图为上述超链接打开之后所看到的页面:

我们将上述代码copy下来(这一大段代码不需要背下来,到了工作当中也是直接去axios官方中直接copy下来我们进行应用即可呦)

1.便于封装操作,我们常会建立一个专门的文件来写下我们的拦截器同基地址作为第一次封装。

【vue2小知识】实现axios的二次封装_初映CY的前说的博客

// 添加请求拦截器
axios.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    return config
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error)
  }
)
// 添加响应拦截器
axios.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response
  },
  function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error)
  }
)

我们将官网的这段代码获取下来了,兄弟姐妹们有没有发现官方甚至连注释都给我们写好了,很清晰明了的介绍了axios拦截器的用法,可知:

axios是我们用于发送Ajax请求之前以及我们在发送请求之后会执行的一个回调函数

2.2axios拦截器使用

1.在项目中先下载下我们的axios

至此我们知道了axiox的基本概念,那怎么在vue项目中引用?使用npm i axios 或者这 yarn add axios 将我们的axios下载下来(使用指南:npm的使用介绍)

2.项目中进行引入(与拦截器在同一个js文件)

import axios from 'axios'

3.设置基地址,并且导入request

const request = axios.create({
  baseURL: 'http://ajax-api.itheima.net/api',
  timeout: 5000 // 超过5s请求停止
})
export default request

4.根据接口文档写axios请求

import request from '@/utils/request'
export function homeAddress (pname, cname) {
  return request({
    url: '/area',
    method: 'GET',
    params: {
      pname: pname,
      cname: cname
    }
  })
}

5.页面中进行调用




6.点击按钮发送请求

7.配置axios拦截器

7.1请求拦截器

在发送请求之前会执行的一个回调,常用于将token添加进请求头的Authorization中。

注意我们的axios实例是request因此从官网cv下来我们需要将axios改为request

// 添加请求拦截器
request.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    console.log(config, 'config')
    console.log('嘿!我是在请求之前就执行的')
    return config // 发给服务器的信息
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error)
  }
)

7.2响应拦截器

从服务器获取到了数据返回的时候先执行一个回调函数,常用于做状态码判断与脱壳处理

// 添加响应拦截器
request.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    console.log(response, 'response')
    console.log('嘿!我是在请求之后就执行的,response为我们请求相应的结果')
    return response.data.data
  },
  function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error)
  }
)

js基础

1)对js的理解?

2)请说出以下代码输出的值?

3)把以下代码,改写成依次输出0-9

4)如何区分数组对象,普通对象,函数对象

5)面向对象、面向过程

6)面向对象的三大基本特性

7)XML和JSON的区别?

8)Web Worker 和webSocket?

9)Javascript垃圾回收方法?

10)new操作符具体干了什么呢?

11)js延迟加载的方式有哪些?

12)WEB应用从服务器主动推送Data到客户端有那些方式?

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

本特性

7)XML和JSON的区别?

8)Web Worker 和webSocket?

9)Javascript垃圾回收方法?

10)new操作符具体干了什么呢?

11)js延迟加载的方式有哪些?

12)WEB应用从服务器主动推送Data到客户端有那些方式?

[外链图片转存中…(img-dl8VitDq-1714837204856)]

[外链图片转存中…(img-aq98K2dh-1714837204857)]

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

转载请注明来自码农世界,本文标题:《2024年Web前端最全【vue2】axios请求与axios拦截器的使用详解,前端高级面试视频》

百度分享代码,如果开启HTTPS请参考李洋个人博客
每一天,每一秒,你所做的决定都会改变你的人生!

发表评论

快捷回复:

评论列表 (暂无评论,56人围观)参与讨论

还没有评论,来说两句吧...

Top