关于wx.request的封装

最近打算自己做个小程序,也在不断学习微信小程序官方文档。然而在小程序中网络请求是也是非常重要的一部分,但是一个应用中会有许多的请求,所以需要对一个请求做一些拦截,于是就像对wx.request方法做一个分装方便使用。

封装之前先看下微信小程序官方的 wx.request 方法使用。
其实官方的请求方法很简单, 就是 wx.request(options) 其中options包含了很多的指定参数。

wx.request({
  url: 'test.php', //仅为示例,并非真实的接口地址
  data: {
     x: '' ,
     y: ''
  },
  header: {
    'content-type': 'application/json' // 默认值
  },
  success: function(res) {
    console.log(res.data)
  }
})

基于我在想如何封装一个方便自己使用的请求方法呢,主要的考虑点如下:

  1. 请求可以统一拦截处理;
  2. 能添加统一公共的请求体参数,例如一些加密处理等;
  3. 请求头部添加公共参数;
  4. 请求统一处理部分。

具体实现步骤

  1. 为了习惯使用封装一个Fetch类
  2. 添加请求Header、状态码处理、请求结果处理。
class Fetch {
    constructor({
        processAuthorizationHeader = () => {},
        processHttpStatusCode = defaultHttpStatusCode,
        processResultHandle = noop
    }) {
        this.processAuthorizationHeader = processAuthorizationHeader;
        this.processHttpStatusCode = processHttpStatusCode;
        this.processResultHandle = processResultHandle;
    }

    fetch(opts) {
        let {
            url,
            data = {},
            header = {},
            method = 'POST', // 有效值:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
            dataType = 'json',
            responseType = 'text',
            complete = noop,
            noStatus = true, // 默认不显示loading
            mask = false, // 不显示遮罩
            loadingText,
        } = opts;
        const self = this;
        // loading icon
        if (!noStatus) {
            wx.showLoading({
                title: loadingText || '加载中…',
                mask: mask
            })
        }

        // 请求头设置
        header = Object.assign({}, this.getUserAuthorizationHeader(), header);

        return new Promise((resolve, reject) => {
            wx.request({
                url,
                data,
                header,
                method,
                dataType,
                responseType,
                complete,
                success: (res) => {
                    wx.hideLoading();
                    // 请求状态码处理
                    const httpStatusCode = res.statusCode;
                    if (!self.processHttpStatusCode(httpStatusCode)) {
                        return reject();
                    }

                    // 请求数据过滤(data默认为json格式)
                    if (typeof res.data === 'string') {
                        try {
                            res.data = JSON.parse(res.data);
                        } catch (e) {}
                    }

                    // 统一添加请求处理
          self.processResultHandle(res) && resolve(res.data);
                },
                fail: (res) => {
                    wx.hideLoading();
                    wx.showToast({
                        title: '网络异常',
                        duration: 1200
                    });
                    reject(res);
                }
            });
        })
    }
}

// 请求默认处理方法
function defaultHttpStatusCode(statusCode) {
    if (statusCode === 200) {
        return true;
  }
  wx.showToast({
    title: '请求异常',
    icon: 'none',
  })
    return;
}

// 空方法
function noop() {
    return true;
}

export default Fetch;

使用方式

  1. 实例化一个Fetch类
  2. 将实例化的对象挂到wx.fetch下面,这样就可以通过wx.fetch的方式处理做请求。
export const myFetch = new Fetch({
  processAuthorizationHeader() {
    return {
      'usercode': wx.getStorageSync('usercode'),
    }
  },
  processHttpStatusCode(statusCode) {
    if (statusCode === 200) {
      return true;
    } else {
      wx.showToast({
        title: '服务器错误',
        icon: 'none',
        duration: 2000
      })
      return false;
    }
  },
  processResultHandle(res) {
    if (+res.data.code === 200) {
      return true;
    } else if (+res.data.code === 401) { // 重新登录
      wx.redirectTo({
        url: '/pages/login/login'
      })
      return false;
    } else { // 错误异常
      wx.showToast({
        title: res.data.msg,
        icon: 'none',
        duration: 2000
      })
      return false;
    }
  }
})

wx.fetch = myFetch.fetch.bind(myFetch); // 将实例化的对象挂到wx.fetch下
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,585评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,398评论 25 707
  • 忙完了,放松了,忽而难过到想死,因为我想起了过往,又做贱了自己,忽而又被感动打湿了眼眶。我很伤心,我的过去有你,但...
    东夙阅读 143评论 0 0
  • 去年年底为舍友临摹的梅长苏,曾在她背包离去前提醒过她一次,可这幅画却终是因被忘记而继续留在了我的画册里。 大概冥冥...
    觅渡雅朵阅读 240评论 2 2
  • 晚安【日精进第75天/3650用生命影响生命!如何过一天就如何过一生! 没有反思的人生不值得过!!(湖北省恩施市)...
    好心情_d8eb阅读 121评论 0 0