亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue2項目中全局封裝axios問題

 更新時間:2022年10月10日 15:39:38   作者:洋養(yǎng)楊陽  
這篇文章主要介紹了vue2項目中全局封裝axios問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue2全局封裝axios

封裝axios

第一步

  • 1.src 目錄中新建utils文件夾
  • 2.utils文件中建立http.js文件

http.js文件的內(nèi)容

//第一步導(dǎo)入axios
import axios from 'axios'
import { Toast } from 'vant';
//第二步 我們可以聲明一個新的常量axios 我們可以配置一些基礎(chǔ) 公共的路徑配置   比如說baseURL timeout請求失敗超時報錯 withcookies...之類的東西
const service = axios.create({
    baseURL: process.env.VUE_APP_BASE_URL//如果配置了環(huán)境變量就可以直接寫/api,
    withCredentials: true,
    timeout: 3000//請求超時
})
//第三步 設(shè)置請求攔截
//新的常量axios service.攔截器.請求.使用===》 里頭有兩個參數(shù) 一個成功的回調(diào)函數(shù)  一個失敗的回調(diào)函數(shù)
service.interceptors.request.use(config=>{
    //每次發(fā)送請求要進行的公共操作  每次發(fā)送請求一般需要的操作一般都有 開啟loading加載動畫 token寫在請求的頭部 之類的
    //loading
    Toast.loading({
        message: '加載中...',
        forbidClick: true,
      });
    //最后的話一定要給他return出去 不return不執(zhí)行
    return config
},err=>{
    //請求的時候如果發(fā)生錯誤了, 這邊直接給它拋出錯誤就行
    // throw new Error(err)拋出的是一個紅色的報錯方便我們查看尋找
    throw new Error(err)
})
//第四步 設(shè)置響應(yīng)攔截
service.interceptors.response.use(response=>{
//我們每次成功發(fā)送一個請求 它都會有響應(yīng)的 參數(shù)也是兩個
    //一般成功之后可以清除或關(guān)閉loading動畫 還可以判斷一些狀態(tài)碼
  //清除loading動畫 
    Toast.clear()
    
    //判斷狀態(tài)碼
    const res = response.data
    if (res.status && res.status !== 200) {
      // 登錄超時,重新登錄
      if (res.status === 401) {
        Toast.loading({
            message: '登錄超時,請從新登錄',
            forbidClick: true,
          });
      }
      return Promise.reject(res || 'error')
    } else {
      return res.data
    }
},err=>{
    return Promise.reject(err)
})
//導(dǎo)出  導(dǎo)出這個模塊
export default service

封裝api 函數(shù)

第一步先在utils文件夾中新建api.js

api.js文件的內(nèi)容

//這邊的話 先導(dǎo)入封裝好的新的axios
import service from './http';
//然后我們可以封裝一些接口函數(shù) 比如說 登錄的 注冊的 首頁的 分類的 輪播的 //但是要確認(rèn)參數(shù)傳的是get還是post請求
//首頁
export function getHome(data){
    return service.get('/home',data)
}
//方便我們后期的維護 代碼美觀 方便快捷
//輪播
export function lunbo(data){
    return service.get('/home/shejishi',data)
}
//比如說以后我們要維護封裝好的接口 這樣封裝好后我們就不需要去組件里一個一個去找,直接來這個文件修改即可
//組件化開模塊化發(fā)或者開發(fā) 它們都有一個原則
//高聚合 低耦合 
//高聚合就是 一個組件的業(yè)務(wù)一定要聚合在一起 一個組件的業(yè)務(wù)越集中越好
//低耦合就是 組件和組件之間的耦合度一定要低 意思就是兩個組件之間的牽連越少越好

vue2.X中axios簡單封裝和多功能封裝

vue2.X 中axios的簡單封裝

簡單封裝說明了封裝思路,適合小白但想嘗試封裝的人。你可以在此基礎(chǔ)上進行追加改造.

1.引入庫

代碼如下(示例):

npm install axios 
npm install element-ui -S
// 或者
yarn add axios
yarn add element-ui

2.創(chuàng)建封裝文件 request.js

代碼如下(示例):

/**
 * 全站http配置
 */
import axios from 'axios';
import { Message } from 'element-ui';
//默認(rèn)超時時間
axios.defaults.timeout = 10000;
//返回其他狀態(tài)碼
axios.defaults.validateStatus = function (status) {
  return status >= 200 && status <= 500;
};
//跨域請求,允許保存cookie
axios.defaults.withCredentials = true;
//http request攔截 ,此處用到es6 Promise
axios.interceptors.request.use(config => {
	// 你可以通過config來配置請求頭...
  const meta = (config.meta || {});
  //headers中配置text請求
  if (config.text === true) {
    config.headers["Content-Type"] = "text/plain";
  }
  //headers中配置serialize為true開啟序列化
  if (config.method === 'post' && meta.isSerialize === true) {
    config.data = serialize(config.data);
  }
  return config
}, error => {
  return Promise.reject(error)
});
//http response 攔截,此處用到es6 Promise
axios.interceptors.response.use(res => {
  //獲取狀態(tài)碼
  const status = res.data.code || res.status;
  const message = res.data.msg || res.data.error_description || '未知錯誤';
  //如果是401則跳轉(zhuǎn)到登錄頁面
  if (status === 401) { 
	//router.push({ path: '/login' }))
  }; 
  // 如果請求為非200否者默認(rèn)統(tǒng)一處理
  if (status !== 200) {
    Message({
      message: message,
      type: 'error'
    });
    return Promise.reject(new Error(message))
  }
  return res;
}, error => {
 
  return Promise.reject(new Error(error));
});
export default axios;

3.使用方式

在vue項目的根目錄下的main.js 正常引用就好啦

import request from './api/request/request.js'  
Vue.prototype.request = request;

接下來去頁面中調(diào)用。這里唯一可能會犯錯的地方

  • 1. url路徑的開頭忘記加 / 了! hhh
  • 2. /api 不明白是干什么的。其實這里是 devServer.proxy 的key
let _self = this;
let id = '123';
let name = 'abner';
let url = '/api/blade-performance-mgt/hzy/performance/record/planSubmit';  // 請求地址
// post 請求
 _self.request
     .post(url, {
         id: id,
         name: name ,
     })
     .then((res) => {
         // res
     });
     
     
// git 請求
let url = '/api/blade-performance-mgt/hzy/performance/record/list;  // 請求地址
_self.request.get(url)
  .then((res) => {
    // res
  });

也發(fā)下vue.config.js的配置吧!

這里只需要看下devServer中的配置就行

module.exports = {
  //路徑前綴
  publicPath: "/",
  lintOnSave: true,
  productionSourceMap: false,
  chainWebpack: (config) => {
    //忽略的打包文件
    config.externals({
      'vue': 'Vue',
      'vue-router': 'VueRouter',
      'vuex': 'Vuex',
      'axios': 'axios',
      'element-ui': 'ELEMENT',
    });
    const entry = config.entry('app');
    entry.add('babel-polyfill').end();
    entry.add('classlist-polyfill').end();
    entry.add('@/mock').end();
  },
  css: {
    extract: { ignoreOrder: true }
  },
  //開發(fā)模式反向代理配置,生產(chǎn)模式請使用Nginx部署并配置反向代理
  devServer: {
    port: 1888,
    proxy: {
      '/api': {
        //本地服務(wù)接口地址
        // target: 'http://localhost',
        //遠程演示服務(wù)地址,可用于直接啟動項目
        target: 'http://10.1.100.248:8000/api',
        // target: 'http://10.1.6.67:8033',
        ws: true,
        pathRewrite: {
          '^/api': '/'
        }
      }
    }
  }
};

多功能封裝

這種為了更好的分離代碼,需要創(chuàng)建兩個文件interceptor.js和request.js

1.創(chuàng)建request文件夾,我的項目目錄如下

interceptor.js 代碼如下

/**
 * Author:abner ,修改于5月28
 * 生成基礎(chǔ)axios對象,并對請求和響應(yīng)做處理
 * 前后端約定接口返回解構(gòu)規(guī)范
 * {
 *    code:200,
 *    data:"成功",
 *    msg: "操作成功"
 *    success: true
 * }
 */
import axios from 'axios'
import { Message } from 'element-ui'
import { getToken } from '@/util/auth'; // 獲取token值的方法,如何沒有用token驗證刪掉即可
// 創(chuàng)建一個獨立的axios實例
const service = axios.create({
    // 設(shè)置baseUr地址,如果通過proxy跨域可直接填寫base地址
    baseURL: '/api',
    // 定義統(tǒng)一的請求頭部
    headers: {
       // 'Authorization': ``, // 此處對應(yīng)后臺AOP驗證,
        'Content-Type': 'application/json' //默認(rèn)方式提交數(shù)據(jù)
        // 'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8' //表單方式提交數(shù)據(jù)
    },
    // 配置請求超時時間
    timeout: 10000,
    // 如果用的JSONP,可以配置此參數(shù)帶上cookie憑證,如果是代理和CORS不用設(shè)置
    withCredentials: true
});
// 請求攔截
service.interceptors.request.use(config => {
    // 在header中自定義token參數(shù)名:tokenHeader,可添加項目token
    config.headers[tokenHeader] =  getToken()
    return config;
});
// 返回攔截
service.interceptors.response.use((response) => {
    // 獲取接口返回結(jié)果
    const res = response.data;
    // code為200,直接把結(jié)果返回回去,這樣前端代碼就不用在獲取一次data.
    if (res.code === 200) {
        return res;
    } else if (res.code === 10000) {
        // 10000假設(shè)是未登錄狀態(tài)碼
        Message.warning(res.msg);
        // 也可使用router進行跳轉(zhuǎn)
        window.location.href = '/#/login';
        return res;
    } else {
        // 錯誤顯示可在service中控制,因為某些場景我們不想要展示錯誤
        // Message.error(res.message);
        return res;
    }
}, () => {
    Message.error('網(wǎng)絡(luò)請求異常,請稍后重試!');
});
export default service;

request.js中你需要知道的

這里需要說明的是請求方式那里的判斷,我們需要知道axios不同請求方式默認(rèn)傳參的方式是不同的,比如:

1.post請求我們一般都用data:{} 這中方式傳參

2.get請求我們一般都用params:{} 這中方式傳參

又比如

//如果服務(wù)端將參數(shù)作為對象來封裝接受
axios.delete('demo/url', {
    data: {
        id: 123,
        name: 'Henry',
    },
     timeout: 1000,
    ...//其他相關(guān)配置
})
//如果服務(wù)端將參數(shù)作為url參數(shù)來接受,則請求的url為:www.demo/url?a=1&b=2形式
axios.delete('demo/url', {
    params: {
        id: 123,
        name: 'Henry',
    },
     timeout: 1000,
    ...//其他相關(guān)配置
})

我們需要對不同的請求,不同的情況進行判斷處理

request.js 代碼如下

/**
 * request.js
 * 通過promise對axios做二次封裝,針對用戶端參數(shù),做靈活配置
 * Author:abner ,修改于5月28
 */
import { Message, Loading } from 'element-ui';
import instance from './interceptor'
/**
 * 核心函數(shù),可通過它處理一切請求數(shù)據(jù),并做橫向擴展
 * @param {url} 請求地址
 * @param {params} 請求參數(shù)
 * @param {options} 請求配置,針對當(dāng)前本次請求;
 * @param loading 是否顯示loading
 * @param mock 本次是否請求mock而非線上
 * @param error 本次是否顯示錯誤
 */
function request(url, params, options = { loading: true, mock: false, error: true }, method) {
    // let loadingInstance = '';
    // 請求前l(fā)oading
    // if (options.loading) loadingInstance = Loading.service({background:'transparent'});
    return new Promise((resolve, reject) => {
        let data = {}
        // get請求使用params字段
        if (method == 'get') data = { params }
        // post請求使用data字段
        if (method == 'post') data = { data: params }
        // delete請求使用params字段
        if (method == 'delete') data = { params }
        // 通過mock平臺可對局部接口進行mock設(shè)置
        if (options.mock) url = 'http://www.mock.com/mock/xxxx/api';
        instance({
            url,
            method,
            ...data
        }).then((res) => {
            // 此處作用很大,可以擴展很多功能。對返回的數(shù)據(jù)進行統(tǒng)一處理
            if (res && res.code === 200) {
                resolve(res.data);
            } else {
                // 通過配置可關(guān)閉錯誤提示
                if (res && options.error) Message.error(res.msg);
                reject(res);
            }
        }).catch((error) => {
            Message.error(error.message)
        }).finally(() => {
            // loadingInstance.close();
        })
    })
}
// 封裝GET請求
function get(url, params, options) {
    return request(url, params, options, 'get')
}
// 封裝POST請求
function post(url, params, options) {
    return request(url, params, options, 'post')
}
// 封裝DELETE請求
function Delete(url, params, options) {
    return request(url, params, options, 'delete')
}
export default {
    get, post, Delete
}

使用步驟

1.在main.js中添加

import request from './api/request/request'
Vue.prototype.request = request;

2.在方法中直接使用

methods: {
        getUnitTabledata() {
            let _self = this;
            _self.request
                .get("/lnjzxh-awards-mgt/lnjzxh/award/serial/unit/list/page", {
                    awardName: _self.searchName,
                    status: _self.statusValue,
                    account: _self.account,
                    createDate: _self.pickerValue,
                    current: _self.page.currentPage - 1,
                    size: _self.page.pageSize,
                })
                .then((res) => {
                    _self.page.total = res.total;
                    _self.tableData = res.records;
                });
        },
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue+element-ui JYAdmin后臺管理系統(tǒng)模板解析

    vue+element-ui JYAdmin后臺管理系統(tǒng)模板解析

    這篇文章主要介紹了vue+element-ui JYAdmin后臺管理系統(tǒng)模板解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 基于Vue實現(xiàn)后臺系統(tǒng)權(quán)限控制的示例代碼

    基于Vue實現(xiàn)后臺系統(tǒng)權(quán)限控制的示例代碼

    本篇文章主要介紹了基于Vue實現(xiàn)后臺系統(tǒng)權(quán)限控制的示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • vuex如何修改狀態(tài)state的方法

    vuex如何修改狀態(tài)state的方法

    這篇文章主要介紹了vuex如何修改狀態(tài)state的方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 詳解關(guān)于Vue單元測試的幾個坑

    詳解關(guān)于Vue單元測試的幾個坑

    這篇文章主要介紹了關(guān)于Vue單元測試的幾個坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 深入淺析Vue不同場景下組件間的數(shù)據(jù)交流

    深入淺析Vue不同場景下組件間的數(shù)據(jù)交流

    探通過本篇文章給大家探討不同場景下組件間的數(shù)據(jù)“交流”的Vue實現(xiàn)方法,感興趣的朋友一起看看吧
    2017-08-08
  • vue element自定義表單驗證請求后端接口驗證

    vue element自定義表單驗證請求后端接口驗證

    這篇文章主要介紹了vue element自定義表單驗證請求后端接口驗證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 深入理解Vue響應(yīng)式原理及其實現(xiàn)方式

    深入理解Vue響應(yīng)式原理及其實現(xiàn)方式

    Vue的響應(yīng)式原理是Vue最核心的特性之一,也是Vue能夠為開發(fā)者提供高效便捷的開發(fā)體驗的重要原因之一,這篇文章主要介紹了響應(yīng)式的原理及其實現(xiàn)方式,需要詳細(xì)了解可以參考下文
    2023-05-05
  • 解決antd datepicker 獲取時間默認(rèn)少8個小時的問題

    解決antd datepicker 獲取時間默認(rèn)少8個小時的問題

    這篇文章主要介紹了解決antd datepicker 獲取時間默認(rèn)少8個小時的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue項目使用js監(jiān)聽瀏覽器關(guān)閉、刷新、后退事件實現(xiàn)方法

    vue項目使用js監(jiān)聽瀏覽器關(guān)閉、刷新、后退事件實現(xiàn)方法

    用vue做的項目,有個需求就是關(guān)閉瀏覽器的時候,需要往后臺提交有個接口,來看看這個賬號有沒有下線,這篇文章主要給大家介紹了關(guān)于vue項目使用js監(jiān)聽瀏覽器關(guān)閉、刷新、后退事件的實現(xiàn)方法,需要的朋友可以參考下
    2024-06-06
  • vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑功能

    在使用 Vue.js 開發(fā)后臺管理系統(tǒng)時,經(jīng)常會遇到需要使用路由標(biāo)簽頁的場景,這篇文章主要介紹了vue3+Typescript實現(xiàn)路由標(biāo)簽頁和面包屑,需要的朋友可以參考下
    2023-05-05

最新評論