ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

vue中axios的封装

2020-09-28 20:31:50  阅读:155  来源: 互联网

标签:src axios http 请求 headers token vue 封装


目录

1.始vue化项目

 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 */
 const axios = require('axios')
 // import qs from 'qs'
 axios.defaults.baseURL = 'http://127.0.0.1:8000';
 axios.defaults.timeout = 10000;
 axios.defaults.withCredentials = true;

/**
 * 设置请求传递数据的格式 (看服务器要求的格式)
 * x-www-form-urlencoded
 * 默认提交表单
 * 把数据对象序列化成表单数据
 */
 // axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded';
 // axios.defaults.transformRequest = data => JSON.stringify(data);


/**
 * 请求拦截器
 */
 axios.interceptors.request.use(config => {
   // 从localStorage中获取token
   let token = localStorage.getItem('token');
   // 如果有token,就把token设置到请求头中Autorization字段中
   token && (config.headers.Authorization = token);
   return config;
 },error => {
   return Promise.reject(error);
 });

 /**
  * 响应拦截器
  */
  axios.interceptors.response.use(response => {
   // 当响应码是 2xx 的情况,进入这里
   debugger
   return response.data;
 },error => {
   // 当响应码不是 2xx 的情况,进入这里
   debugger
   return error
 });
 /**
  * get方法,对应get请求
  * @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(ree.data)
      })
    })
 }
 export default axios;    

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

 /* eslint-disable */
 // 接口信息,生成请求方法
 // 引入get方法,post方法
 import { get,post } from './indes'

 // 用户登陆
 export const login = (params,headers) => post("/user/login/",params,headers)

标签:src,axios,http,请求,headers,token,vue,封装
来源: https://www.cnblogs.com/steve-/p/13746714.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有