pp电子

登录
免费开通

微信小程序api阻挡器

这里为各人介绍微信小程序api阻挡器,,,,,,微信小程序api阻挡器完善兼容原生小程序项目完善兼用小程序api的原本挪用方式。。。

微信小程序api阻挡器

  • 完善兼容原生小程序项目
  • 完善兼用小程序api的原本挪用方式,,,,,,无痛迁徙
  • 小程序api全Promise化
  • 和axios一样的请求方式
  • 小程序api自界说阻挡挪用参数和返回效果
  • 强盛的async阻挡
快速最先

装置
npm install wxapp-api-interceptors --save

使用

mpvue等项目
import wxApiInterceptors from 'wxapp-api-interceptors';

wxApiInterceptors(); // 必需在挪用小程序api之前挪用

原生小程序项目

下载该项目,,,,,,解压移动文件夹dist里wxApiInterceptors.js和runtime.js文件到你自己的项目,,,,,,详见示例。。。

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

wxApiInterceptors(); // 必需在挪用小程序api之前挪用

小程序api挪用

不必传success、complete和fail参数。。。

??注重:原生小程序项目不支持Promise.finally

函数式异程序用方式:

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

也兼容原生的挪用方式(未便维护):
wx.showLoading({
    title: '登录中...',
    success: () => {
        wx.login({
            success: (data) => {
                wx.request({
                    url: '/login',
                    data,
                    success: () => wx.showToast({title: '登录乐成'}),
                    fail: () => wx.showToast({title: '登录失败'}),
                    complete: wx.hideLoading,
                });
            },
        });
    },
});

自界说阻挡器

使用要领及参数:wxApiInterceptors({[api]: {[request](params):params, [response](res):res}})

好比阻挡wx.showModal的confirmColor默认值为red,,,,,,挪用乐成后并阻挡挪用乐成返回的效果。。。

wxApiInterceptors({
    showModal: {
        request(params) {
            if (params.confirmColor === undefined) {
                params.confirmColor = 'red';
            }
            return params;
        },
        response(res) {
            res = '挪用乐成';
            return res;
        },
    }
});

wx.showModal({title: '测试'})
    .then(console.log);
// 控制的输出:挪用乐成

默认阻挡了request api,,,,,,封装成了和axios差未几的使用方式

挪用wx.request[method](url, [config])发送axios化的请求。。。

默认GET请求

wx.request('https://test.com/banner')
    .then(({data}) => {
        console.log(data);
    })
其他请求方式
wx.request.post('https://test.com', {data: {userName: 'test'}})
    .then(({data}) => {
        console.log(data);
    })
虽然也可以再继续阻挡request api

好比设置request api默认的host:

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

甚至可以阻挡自己的营业状态码:

wxApiInterceptors({
    request: {
        response(res) {
            const {data: {code}} = res;
            // 若是data里的code即是-1就响应为失败
            if (code === -1) {
                return Promise.reject(res);
            }
            return res;
        },
    },
});
强盛的async阻挡器

好比挪用request api的时间都在header里带受骗地贮存的token,,,,,,没有的话从服务器获取。。

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阻挡器


【本站声明】
  1、本站文章中所选用的图片及文字泉源于网络以及用户投稿,,,,,,由于未联系到知识产权人或未发明有关知识产权的挂号,,,,,,若有知识产权人并不肯意我们使用,,,,,,若是有侵权请连忙联系。。。
  2、本网站差池文章中所涉及的内容真实性、准确性、可靠性认真,,,,,,仅系客观性形貌,,,,,,如您需要相识该类商品/服务详细的资讯,,,,,,请您直接与该类商品/服务的提供者联系。。。


KESION pp电子软件

KESION pp电子软件是海内领先的在线教育软件及私域社交电商软件服务提供商,,,,,,恒久专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。。。
公司焦点产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化自力安排品牌网校和在线教育咨询等。。。

KESION 一直通过手艺立异,,,,,,提供产品和服务,,,,,,助力企业向数字化转型,,,,,,通过科技驱动商业刷新,,,,,,让商业变得更智慧!



▼点击进入pp电子官网相识更多



热门标签
微信小程序 SaaS
上/下篇
换一换相关推荐
精选内容
热门精选
pp电子·模拟器(试玩游戏)官方网站 pp电子·模拟器(试玩游戏)官方网站 pp电子·模拟器(试玩游戏)官方网站
【网站地图】
微信小程序api阻挡器 - KESION pp电子