微信小程序接口封装

773 阅读2分钟

写该篇文章就是为自己以后开发小程序项目方便CV

007122D4.jpg
一、接口开发流程 image.png 二、微信公众平台域名配置
注意:一定要配置https,小程序上配置的域名必须是域名备案的,还有一定服务器要TLS1.2以上

image.png
打开微信开发者工具,打开你的项目,点开详情。确认一下域名是否一一匹对

image.png
三、在你的项目文件utils 文件中新建api.js http.js

image.png
http.js 代码(复制过去就可以了)

  http(url, method, params) {
    let token = 'token' // 获取token,自行获取token和签名,token和签名表示每个接口都要发送的数据
    let sign = 'sign' // 获取签名 (后台怎么定义的,就传什么)
    let data = {
      token,
      sign
    }
    if (params.data) { // 在这里判断一下data是否存在,params表示前端需要传递的数据,params是一个对象,有三组键值对,data:表示请求要发送的数据,success:成功的回调,fail:失败的回调,这三个字段可缺可无,其余字段会忽略
      for (let key in params.data) { // 在这里判断传过来的参数值为null,就删除这个属性
        if (params.data[key] == null || params.data[key] == 'null') {
          delete params.data[key]
        }
      }
      data = { ...data, ...params.data }
    }
    wx.request({
      url: '你配置的域名' + url, // 就是拼接上前缀,此接口域名是开放接口,可访问
      method: method == 'post' ? 'post' : 'get', // 判断请求类型,除了值等于'post'外,其余值均视作get 其他的请求类型也可以自己加上的
      data,
      header: {
        'content-type': 'application/json'
      },
      success(res) {
        params.success && params.success(res.data)
      },
      fail(err) {
        params.fail && params.fail(err)
      }
    })
  }
}

api.js(再次复制代码 就可以了)

import { http } from './http'; // 引入刚刚封装好的http模块,import属于ES6的语法,微信开发者工具必须打开ES6转ES5选项

function femaleNameApi(params) { // 请求接口
  http('project/projectInfos', 'get', params)  // 接口请求的路由地址以及请求方法在此处传递
}

// 每一个接口定义一个函数,然后暴露出去,供逻辑代码调用

function novelApi(params) { // 接口
  http('/novelApi', 'get', params)
}

export default { // 暴露接口
  femaleNameApi,
  novelApi
}

调用(你想在哪里用就在哪里用)


Page({
  onLoad: function () {

    this.getData()
  },

  getData(){
    http.femaleNameApi({ // 调用接口,传入参数
      data: {
        token: '470712FF0FE2392D6CB6D8A6560805CC'
      },
      success: res => {
        console.log('接口请求成功', res)
        this.setData({
          femaleList: res.data
        })
      },
      fail: err => {
        console.log(err)
      }
    })
  }
})

本文章借鉴于www.cnblogs.com/ifannie/p/1…

0073030D.jpg