1. 始vue化项目

https://www.cnblogs.com/xiaonq/p/11027880.html

vue init webpack deaxios     # 使用脚手架创建项目 deaxios(项目名,随便取得)

cd deaxios                   # 进入项目

npm install axios -S         # 安装axios

2.封装axios

2.1 src文件夹下新建http文件夹, 用来放网络请求相关的文件
2.2 src/http文件夹下, 创建index.js文件, 对axios进行封装

/* eslint-disable */ //第一步:实例化axios对象,并设置 1.请求地址;2.超时时间;3.设置请求头数据格式

const axios = require('axios');   // 创建axios对象

// import qs from 'qs'

axios.defaults.baseURL = 'http://192.168.56.100:8888';    // vue请求后端地址

axios.defaults.timeout = 10000;                           // 多久超时

axios.defaults.withCredentials = true;                    // 跨域访问需要发送cookie

时一定要加axios.defaults.withCredentials = true;
/** * 设置请求传递数据的格式(看服务器要求的格式)

* x-www-form-urlencoded *

默认提交表单 * 把数据对象序列化成 表单数据 */

// axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded';

// axios.defaults.transformRequest = data => qs.stringify(data);
/**

* 设置默认提交 json

* 把数据对象序列化成 json 字符串

*/ axios.defaults.headers['Content-Type'] = 'application/json';

// 设置默认提 交 json axios.defaults.transformRequest = data => JSON.stringify(data);

// 把数据对象 序列化成 json 字符串
// 第二步:对请求拦截器,和响应拦截器进行封装

/** * 请求拦截器: 发送请求前需要调用这个函数

1.当没有登录时,直接跳转到登录页

2.请求发送前把token获取,设置到header

中 */

axios.interceptors.request.use(config => {

// 从localStorage中获取token

let token = localStorage.getItem('token');

// 如果有token, 就把token设置到请求头中Authorization字段中

token && (config.headers.Authorization = token);

return config;

}, error => {

return Promise.reject(error);

});
/**

* 响应拦截器:当后端返回数据给vue时会调用这个函数

1.没次返回403错误时,跳转到login

*/ axios.interceptors.response.use(response => {

// 当响应码是 2xx 的情况, 进入这里

debugger

return response.data;

}, error => {

// 当响应码不是 2xx 的情况, 进入这里

debugger

return error });
//第三步:使用上面的axios对象,对get请求和post请求进行封装

/** * get方法,对应get请求

* @param {String} url [请求的url地址]

* @param {Object} params [请求时携带的参数]

*/

export function get(url, params, headers) {

return new Promise((resolve, reject) => {

axios.get(url, { params, headers }).then(res => {

resolve(res.data.ResultObj)   }).catch(err => {

reject(err.data)

})

})

}
/**

* post方法,对应post请求

* @param {String} url [请求的url地址]

* @param {Object} params [请求时携带的参数]

**/

export function post(url, params, headers) {

return new Promise((resolve, reject) => {

axios.post(url, params, headers).then((res) => {

resolve(res.data)   }).catch((err) => {
     debugger

reject(err.data)

})

})

}

export default axios;  //一定要导出函数

2.3 src/http 目录下创建 apis.js文件, 用来写 接口地址列表

/* eslint-disable */

// 接口信息, 生成请求方法

// 引入 get方法, post方法

import { get, post } from './index'
// 用户登录

export const login = (params, headers) => post("/user/login/", params, headers)

day3(axios封装)的更多相关文章

  1. axios封装

    前言 作为出入vue的小萌新,我在写请求的时候,也是毫不犹豫写了ajax,结果肯定是不行的... Vue 原本有一个官方推荐的 ajax 插件 vue-resource,但是自从 Vue 更新到 2. ...

  2. vue2.0 axios封装、vuex介绍

    一.前言 博主也是vue道路上的行者,道行不深,希望自己的东西能对大家有所帮助.这篇博客针对 了解过vue基础,但是没有做过vue项目的童鞋.如果想看基础指令,可以看我之前的一篇博客,请点击  跳转, ...

  3. 把axios封装为vue插件使用

    前言 自从Vue2.0推荐大家使用 axios 开始,axios 被越来越多的人所了解.使用axios发起一个请求对大家来说是比较简单的事情,但是axios没有进行封装复用,项目越来越大,引起的代码冗 ...

  4. vue项目搭建 (二) axios 封装篇

    vue项目搭建 (二) axios 封装篇 项目布局 vue-cli构建初始项目后,在src中进行增删修改 // 此处是模仿github上 bailicangdu 的 ├── src | ├── ap ...

  5. 原生js上传图片遇到的坑(axios封装)

    后台给我写了一个上传图片的接口,自己用form表单测试成功 接口可以正常跳转 测试的代码: <!doctype html> <html lang="en"> ...

  6. vue-cli3中axios如何跨域请求以及axios封装

    1. vue.config.js中配置如下 module.exports = { // 选项... // devtool: 'eval-source-map',//开发调试 devServer: { ...

  7. axios interceptors 拦截 , 页面跳转, token 验证 Vue+axios实现登陆拦截,axios封装(报错,鉴权,跳转,拦截,提示)

    Vue+axios实现登陆拦截,axios封装(报错,鉴权,跳转,拦截,提示) :https://blog.csdn.net/H1069495874/article/details/80057107 ...

  8. 【Vue】axios封装,更好的管理api接口和使用

    在现在的前端开发中,前后端分离开发比较主流,所以在封装方法和模块化上也是非常需要掌握的一门技巧.而axios的封装也是非常的多,下面的封装其实跟百度上搜出来的axios封装或者axios二次封装区别不 ...

  9. vue3.0+vite+ts项目搭建-axios封装(六)

    封装方式一 import axios from 'axios' import qs from 'qs' import { Toast } from 'vant' import Lockr from ' ...

随机推荐

  1. Elasticsearch数据库 | Elasticsearch-7.5.0应用搭建实战

    Elasticsearch 是一个可用于分布式以及符合RESTful 风格的搜索和数据分析引擎.-- Elastic Stack 官网 搭建Elasticsearch的"那些事儿" ...

  2. 1 Prism概述

    架构目标 以模块化方式开发应用,这些模块被独立团队用WPF技术开发,集成,部署,这是使用Prism的最大好处. 最小化交叉团队依赖.允许团队在不同领域专业化,比如UI设计,商业逻辑实现,基础代码开发 ...

  3. 主题包含一张index.html

    有半年之久没有更新新作品了,但这个小小领地我并没有忘记,我会坚持下去,一直在这等你,等你的每次回眸,感恩你的每次驻足,这已经足够成为我坚守的动力和理由,尽管现在有很多不足和不尽人意,也没很多的时间管理 ...

  4. MySQL全面瓦解10:分组查询和聚合函数

    概述 相信我们经常会遇到这样的场景:想要了解双十一天猫购买化妆品的人员中平均消费额度是多少(这可能有利于对商品价格区间的定位):或者不同年龄段的化妆品消费占比是多少(这可能有助于对商品备货量的预估). ...

  5. [MIT6.006] 22. Daynamic Programming IV: Guitar Fingering, Tetris, Super Mario Bro. 动态规划IV:吉他指弹,俄罗斯方块,超级玛丽奥

    之前我们讲到动态规划五步中有个Guessing猜,一般情况下猜有两种情况: 在猜和递归上:猜的是用于解决更大问题的子问题: 在子问题定义上:如果要猜更多,就要增加更多子问题. 下面我们来看如果像背包问 ...

  6. HotSpot源码分析之类模型

    HotSpot采用了OOP-Klass模型描述Java的类和对象.Klass模型采用Klass类及相关子类的对象来描述具体的Java类.一般HotSpot JVM 在加载Java的Class 文件时, ...

  7. linux中使用head,tail,grep, sed,awk三种方法显示文档中间若干行(指定任意行)

    需要显示文本中间20-25行. 创建一个30行的文档,命名为30.txt并显示在屏幕 [root@v2-ui data]# seq 30 > 30.txt && cat 30.t ...

  8. 【C++】sort函数使用方法

    一.sort函数 1.sort函数包含在头文件为#include<algorithm>的c++标准库中,调用标准库里的排序方法可以实现对数据的排序,但是sort函数是如何实现的,我们不用考 ...

  9. Guitar Pro吉他指弹入门——双手泛音

    曾经有一段时间在琴行里经常遇到有人来试琴,很多人试弹得曲子就是郑成河的<Flaming>,直译过来就是热情的意思.这首曲子里面有很多泛音存在,吉他泛音类似于钟鸣或者摇铃的声音,是一种令人耳 ...

  10. IDM下载器:站点抓取相关设置介绍

    Internet Download Manager(简称IDM)是一款十分好用资源下载器,它的站点抓取功能不仅可以下载被过滤器指定所需文件,例如一个站点的所有图片,或者一个站点的所有音频,也可以下载站 ...