vue如何封装Axios的get、post请求

目录
  • 封装Axios的get、post请求
    • 1.封装Axios基础配置
    • 2.封装网络请求
    • 3.vue中使用
  • vue axios两种方法(封装和不封装)get请求和post请求
    • 一.没有封装的用法
    • 二.封中之后的用法

封装Axios的get、post请求

Axios在vue项目中用的较多,每次都要写一遍很是不方便,尤其其中的config配置项是公用的,完全可以封装一下,这样下次再用就可以直接CV了!毕竟CV大法香啊!

1.封装Axios基础配置

创建一个request.js 文件,内容如下,我把解释性文字放在注释里了。

import axios from 'axios'
export function request(config) {
  // 1.创建axios的实例
  const instance = axios.create({
    // 设置基础的url配置项,这样接口处的url前面就不用写url:'http://127.0.0.1:8000/api/home',直接写成 url:'/api/home', 就可以了
    baseURL: 'http://127.0.0.1:8000/',
    //设置请求超时时间
    timeout: 5000
  })
  // 2.axios的拦截器,用不到的可以忽略这节
  // 2.1.请求拦截的作用
  instance.interceptors.request.use(config => {
    return config
  }, err => {
    console.log('请求拦截err: '+err);
  })
  // 2.2.响应拦截
  instance.interceptors.response.use(res => {
    return res.data
  }, err => {
        console.log('响应拦截err: '+err);
  })
  // 3.发送真正的网络请求
  return instance(config)
}

2.封装网络请求

我们可以将相关的网络请求都放在一个js中,这样再使用和修改的时候就方便查找了。其中get请求比较简单,post 的请求根据传对象输类型不同,要做不同设置。

现在来说说post请求常见的数据格式(content-type)

Content-Type: application/json : 请求体中的数据会以json字符串的形式发送到后端,这种是axios默认的请求数据类型,我们只需将参数序列化json字符串进行传递即可,无需多余的配置。

Content-Type: application/x-www-form-urlencoded:请求体中的数据会以普通表单形式(键值对)发送到后端

Content-Type: multipart/form-data: 它会将请求体的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。

创建一个network.js 文件,内容如下:

// 导入封装好的Axios
import {request} from './request' //注意request.js的相对路径问题
//1. get请求---获取首页的多个数据
export function getHomeMultidata() {
  return request({
    url:'/api/home',
    method:'get',
    // 可以带参数也可以不带参数
    // params: {
    //     userName: 'Lan',
    //     password: '123'
    // }
  })
}
// 2.1 post请求---传输json数据时,获取电视剧多个数据
export function getTvshowMultidata() {
  return request({
    url:'/api/Tvshow',
     headers: {
      'Content-Type': 'application/json'
    },
    method:'post',
    data: {
        userName: 'Lan',
        password: '123'
     }
  })
}
//2.2 post请求---传输文件流,表单Form Data 数据时
export function getMovieMultidata() {
  return request({
    url:'/api/Movie',
    headers: {
    'Content-Type': 'multipart/form-data';
    },
    method:'post',
    data: {
        userName: 'Lan',
        password: '123'
     }
  })
}

3.vue中使用

在script 标签中按需导入network.js 中需要使用的方法

import {getHomeMultidata} from "network/home/network"; //导入js,路径自己根据文件位置设置

在方法中按照promise的格式调用函数即可

created() {
      // 在方法中调用函数即可
        getHomeMultidata().then(
          res => {
          // 此处res 为返回的数据,将返回的数据进行处理显示
            this.banners = res.homedata.slice(0,5)
            this.newestData = res.homedata.slice(5,12)

        ).catch(
          err => {
            console.log(err)
          }
        );
    },

network中的其他网络请求方法使用方法同上。

vue axios两种方法(封装和不封装)get请求和post请求

一.没有封装的用法

1.首先在项目中下载axios

npm install axios -s //此方法会将axios下载到package.json中的"dependencies"模块中,大家可以自行查看

2.因为没有封装所以需要在单个vue组件中的编写js的地方进行引用axios;语法如下

<script>
import axios from  ' axios'
</script>

3.然后在生命周期函数中进行调用数据

export default{ 
created() {
 
      //get请求    
    axios.get("url", {
 
      params: { //此处为get请求传递的参数 但是一把get请求是没有参数的 params是固定的
          password: "123456",
         userName: "320621200305185129",
        },
      })
      
 
     .then(function (response) {
       console.log(response, 666666);
     })
     .catch(function (error) {
        console.log(error, 44444);
      });
      
  },
}
 
//post请求
axios.post('url', {
//此处是参数
    firstName: 'Fred',
    lastName: 'Flintstone'
  })
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });

每个项目的的接口都是不一样的,很多时候代码都不是唯一性的,要灵活的运用

二.封中之后的用法

首先一个目录utils,在该目录下创建request.js 在里面编写

import axios from 'axios'
 
 
export function request(config) {
  // 1.创建axios的实例
  const instance = axios.create({
    // 设置基础的url配置项,这样接口处的url前面就不用写了
 
    baseURL: 'http://192.168.0.112:9518/', 基础代码
    //设置请求超时时间
    timeout: 5000 
  })
 
  // 2.axios的拦截器,用不到的可以忽略这节
  // 2.1.请求拦截的作用
  instance.interceptors.request.use(config => {
    return config
  }, err => {
    console.log('请求拦截err: '+err);
  })
 
  // 2.2.响应拦截
  instance.interceptors.response.use(res => {
    return res.data
  }, err => {
        console.log('响应拦截err: '+err);
  })
 
  // 3.发送真正的网络请求
  return instance(config)
}

然后在目录下创建api在此处创建index.js  在此处引用上方创建axios实例

import {request} from '../utils/request'
 
//get请求
 
export function denglu() {
  return request({
    url: 'login',
    method: 'get',
    params:{ //此处为传递的参数 //get请求一般是不传递参数的
        password:'123456',
        uerName:'5555555555'
    }
    // header: { // 已经在request.js里面进行全局设置,也可以在请求里面局部设置其他headers
    //    'Content-Type': 'text/plain'
    // }
  })
}
 //post请求
export function denglu() {
  return request({
    url: 'login',
    method: 'post',
    data:{ //此处为传递的参数
        password:'123456',
        uerName:'5555555555'
    }
    // header: { // 已经在request.js里面进行全局设置,也可以在请求里面局部设置其他headers
    //    'Content-Type': 'text/plain'
    // }
  })
}

然后需要在vue组件的中 在编写js的地方引入index.js

<script>
import denglu from  "../api/index"
</script>

之后就可以在vue组件方法中进行应用了,下面是我在vue组件中根据上面的代码进行应用的实例

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 如何用vue封装axios请求

    其实vue封装axios是很简单的 首先 在src路径下建http文件夹 并且创建api.js env.js request.js 这三个文件 env.js文件 这个文件主要就是封装我们的公共地址 export default { // 开发环境 dev: { baseUrl: "开发环境公共地址" }, // 测试环境test test: { baseUrl: "测试环境公共地址" }, //线上接口 prod: { baseUrl: "线上环境公共地址

  • vue axios数据请求get、post方法及实例详解

    我们常用的有get方法以及post方法,下面简单的介绍一下这两种请求方法 vue中使用axios方法我们先安装axios这个方法 npm install --save axios 安装之后采用按需引入的方法,哪个页面需要请求数据就在哪个页面里引入一下. import axios from 'axios' 引入之后我们就可以进行数据请求了,在methods中创建一个方法 methods:{ getInfo(){ let url = "url" axios.get(url).then((r

  • vue 2.x 中axios 封装的get 和post方法

    vue 2.x axios 封装的get 和post方法 import axios from 'axios' import qs from 'qs' export class HttpService { Get(url, data) { return new Promise((resolve, reject) => { axios.get(url, { params: data }).then((res) => { if (res) { //成功回调 resolve(res); } }).ca

  • Vue简单封装axios之解决post请求后端接收不到参数问题

    1.在src/下新建api文件夹,api/下新建index.js和public.js 在public.js中: import axios from 'axios'; import qs from 'qs' import router from '../router' import { MessageBox} from 'mint-ui' // 注意点,按照以下写 var instance = axios.create(); instance.defaults.timeout = 10000; i

  • Vue简单封装axios网络请求的方法

    目录 Vue简单封装axios网络请求 一.utils下的httpUtils.js: 二./api下的path.js: 三./api下的index.js: 四.组件中引入并请求: Vue简单封装axios网络请求 一.utils下的httpUtils.js: import axios from 'axios'; import querystring from 'querystring'; const errorHandler = (status, info) => { switch(status

  • vue简单封装axios插件和接口的统一管理操作示例

    本文实例讲述了vue简单封装axios插件和接口的统一管理操作.分享给大家供大家参考,具体如下: 现在很多公司的项目都是前后端分离的项目,那么说到前后端分离,必定会有ajax请求来获得后台的数据. 在做jquery项目的时候,我们都会使用它封装好的方法来直接发起ajax请求. 在vue项目中,我们使用最多的就是axios这个插件,下面就简单的封装下这个插件并且把接口给统一化管理. 一.安装和配置 1.在项目根目录下打开终端安装 npm install axios -S 2.安装完成以后,在src

  • vue中封装axios并实现api接口的统一管理

    在vue项目中,我们通常都是使用axios与后台进行数据交互,axios有很多好用的特性,这里不多做介绍,相关细节可以查阅axios中文网.在对axios进行封装之前,我们要使用vue脚手架工具创建一个vue项目(这里我用的是cli4). 安装 cnpm install axios --save-dev; // 安装axios cnpm install qs --save-dev; // 安装qs模块,用来序列化post类型的数据,否则后端无法接收到数据 模块引入 在src目录下创建一个serv

  • vue如何封装Axios的get、post请求

    目录 封装Axios的get.post请求 1.封装Axios基础配置 2.封装网络请求 3.vue中使用 vue axios两种方法(封装和不封装)get请求和post请求 一.没有封装的用法 二.封中之后的用法 封装Axios的get.post请求 Axios在vue项目中用的较多,每次都要写一遍很是不方便,尤其其中的config配置项是公用的,完全可以封装一下,这样下次再用就可以直接CV了!毕竟CV大法香啊! 1.封装Axios基础配置 创建一个request.js 文件,内容如下,我把解

  • 在Vue中是如何封装axios

    目录 1.安装 1.引入 3.接口根地址 4.使用事例 4.1下载 4.2get 4.3post 1.安装 npm install axios; // 安装axios 1.引入 import axios from 'axios' 3.接口根地址 const baseUrl = API_BASE_URL // 由webpack的插件DefinePlugin注入 webpackConfig .plugin('define') .use(require('webpack/lib/DefinePlugi

  • 使用async await 封装 axios的方法

    es6 的promise 逐步解决了层层回调的问题,es8的async await让异步变成了同步的写法,在vue中,可以通过封装axios,使得所有的请求都可以使用同步写法,同时处理错误信息等,可以建一个api.js文件,全局创建api实例. import axios from 'axios' const qs = require('qs') const api = { async get (url, data) { try { let res = await axios.get(url, {

  • Vue封装Axios请求和拦截器的步骤

    PS:本文代码在vue-cli3构建的基础vue项目之上进行编写:vue create my-project axios 是一个基于 promise 的 http 库,可以用在浏览器和 node.js 中, 也是vue官方推荐使用的http库. axios很好用,其中之一就是它的拦截器十分强大,我们可以为请求和响应设置拦截器,比如请求拦截器可以在每个请求里加上token,做了统一处理后维护起来也方便,响应拦截器可以在接收到响应后先做一层操作,如根据状态码判断登录状态.授权. 之前初学的时候,经常

  • Vue项目中如何封装axios(统一管理http请求)

    1.需求说明 在使用Vue.js框架开发前端项目时,会经常发送ajax请求服务端接口,在开发过程中,需要对axios进一步封装,方便在项目中的使用. 2.Vue项目结构 在本地创建Vue项目,目录结构如下: - public  静态资源文件  - src  |- assets  静态资源目录  |- components 公共组件目录  |- http   axios封装目录  |- router  路由管理目录  |- store  状态管理目录  |- views  视图组件目录  |- A

随机推荐