商城系統(tǒng) 注冊(cè)

微信小程序api攔截器

2020-09-27|HiShop
導(dǎo)讀:微信 小程序 api攔截器 完美兼容原生小程序項(xiàng)目 完美兼用小程序api的原本調(diào)用方式,無(wú)痛遷移 小程序api全Promise化 和axios一樣的請(qǐng)求方式 小程序api自定義攔截調(diào)用參數(shù)和返回結(jié)果 強(qiáng)大...

這里為大家介紹微信小程序api攔截器,微信小程序api攔截器完美兼容原生小程序項(xiàng)目完美兼用小程序api的原本調(diào)用方式。

微信小程序api攔截器

  • 完美兼容原生小程序項(xiàng)目
  • 完美兼用小程序api的原本調(diào)用方式,無(wú)痛遷移
  • 小程序api全Promise化
  • 和axios一樣的請(qǐng)求方式
  • 小程序api自定義攔截調(diào)用參數(shù)和返回結(jié)果
  • 強(qiáng)大的async攔截
快速開(kāi)始

安裝
npm install wxapp-api-interceptors --save

使用

mpvue等項(xiàng)目
import wxApiInterceptors from 'wxapp-api-interceptors';

wxApiInterceptors(); // 必須在調(diào)用小程序api之前調(diào)用

原生小程序項(xiàng)目

下載該項(xiàng)目,解壓移動(dòng)文件夾dist里wxApiInterceptors.js和runtime.js文件到你自己的項(xiàng)目,詳見(jiàn)示例。

const wxApiInterceptors = require('./wxApiInterceptors');

wxApiInterceptors(); // 必須在調(diào)用小程序api之前調(diào)用

小程序api調(diào)用

不必傳success、complete和fail參數(shù)。

??注意:原生小程序項(xiàng)目不支持Promise.finally

函數(shù)式異步調(diào)用方式:

wx.showLoading({title: '登錄中...'})
    .then(wx.login)
    .then(data => wx.request.post('/login', {data}))
    .then(() => wx.showToast({title: '登錄成功'}))
    .catch(() => wx.showToast({title: '登錄失敗'}))
    .finally(wx.hideLoading);

也兼容原生的調(diào)用方式(不便維護(hù)):
wx.showLoading({
    title: '登錄中...',
    success: () => {
        wx.login({
            success: (data) => {
                wx.request({
                    url: '/login',
                    data,
                    success: () => wx.showToast({title: '登錄成功'}),
                    fail: () => wx.showToast({title: '登錄失敗'}),
                    complete: wx.hideLoading,
                });
            },
        });
    },
});

自定義攔截器

使用方法及參數(shù):wxApiInterceptors({[api]: {[request](params):params, [response](res):res}})

比如攔截wx.showModal的confirmColor默認(rèn)值為red,調(diào)用成功后并攔截調(diào)用成功返回的結(jié)果。

wxApiInterceptors({
    showModal: {
        request(params) {
            if (params.confirmColor === undefined) {
                params.confirmColor = 'red';
            }
            return params;
        },
        response(res) {
            res = '調(diào)用成功';
            return res;
        },
    }
});

wx.showModal({title: '測(cè)試'})
    .then(console.log);
// 控制的輸出:調(diào)用成功

默認(rèn)攔截了request api,封裝成了和axios差不多的使用方式

調(diào)用wx.request[method](url, [config])發(fā)送axios化的請(qǐng)求。

默認(rèn)GET請(qǐng)求

wx.request('https://test.com/banner')
    .then(({data}) => {
        console.log(data);
    })
其他請(qǐng)求方式
wx.request.post('https://test.com', {data: {userName: 'test'}})
    .then(({data}) => {
        console.log(data);
    })
當(dāng)然也可以再繼續(xù)攔截request api

比如設(shè)置request api默認(rèn)的host:

wxApiInterceptors({
    request: {
        request(params) {
            const host = 'https://test.com'
            if (!/^(http|\/\/)/.test(params.url)) {
                params.url = host + params.url;
            }
            return params;
        },
    },
});

甚至可以攔截自己的業(yè)務(wù)狀態(tài)碼:

wxApiInterceptors({
    request: {
        response(res) {
            const {data: {code}} = res;
            // 如果data里的code等于-1就響應(yīng)為失敗
            if (code === -1) {
                return Promise.reject(res);
            }
            return res;
        },
    },
});
強(qiáng)大的async攔截器

比如調(diào)用request api的時(shí)候都在header里帶上本地儲(chǔ)存的token,沒(méi)有的話從服務(wù)器獲?。?/p>

wxApiInterceptors({
    request: {
        async request(params) {
            if (params.header === undefined) {
                params.header = {};
            }
            let token = wx.getStorageSync('token');
            if (!token) {
                ({data: token} = await wx.request('/getToken'));
                wx.setStorageSync('token', token);
            }
            params.header.token = token;
            return params;
        },
    },
});

微信小程序api攔截器

電話咨詢 預(yù)約演示 0元開(kāi)店