如何怎么封装微信小程序的数据请求的

方式一:

1、在小程序的目录下新建一个 api 的文件夹

2:在 api 文件夹中新建一个 config.js 文件,用于存放公共的服务器地址,内容如下:

const baseUrl = 'https://www.baidu.com/';

export {

baseUrl

}

3:在 api 文件夹中新建一个 request.js 文件,用于存放封装的api请求,内容如下:

import { baseUrl } from './http.js'

module.exports = {

/*

* url:请求的接口地址

* methodType:请求方式

* data: 要传递的参数

*/

request : function(url, methodType, data){

let fullUrl = `{baseUrl}{url}`

let token = wx.getStorageSync('token') ? wx.getStorageSync('token') : ''

wx.showLoading({ title: "加载中" });

return new Promise((resolve,reject)=>{

wx.request({

url: fullUrl,

method:methodType,

data,

header: {

'content-type': 'application/json', // 默认值

'x-api-key': token,

},

success: (res) => {

if (res.data.status == 200) {

resolve(res.data)

}else{

wx.showToast({

title: res.data.msg,

icon:'none'

})

reject(res.data.message)

}

},

fail: () => {

wx.showToast({

title: '接口请求错误',

icon:'none'

})

reject('接口请求错误')

},

complete: () => {

setTimeout(() => {

wx.hideLoading()

}, 100)

}

})

})

}

}

4:在 api 文件夹中新建一个 index.js 文件,用于存放api请求的地址,内容如下:

import { request } from './request'

module.exports = {

// 获取企业列表

getCompanyList: (data) => request('/company/getlist', 'GET', data),

}

5:在文件中使用,内容如下:

// 引入 api 下的 index 文件

const $api = require('../../api/index')

// 在方法中调用

goList(){

let data = {

aaa: this.data.cardCur,

bbb: this.data.notice,

}

$api.getCompanyList(data).then((res) => {

console.log(res,'res');

})

},

方式二:

前3步是一样的,区别就是封装请求的不同

封装所有请求 api/http.js

//引入封装的reuest请求

const {

request

} = require('./request.js')

//基于业务封装的接口

module.exports = {

// 登录

getLogin: (data) => {

return request('/***/***/***/login', 'POST', data);

},

// 获取企业信息

getCompanyList: (data) => {

return request('/***/***/***/Company', 'GET', data);

},

}

使用

// 引入登录接口

import {

getLogin

} from '../../api/http.js'

Page({

data: {

username: '',

pwd: ''

},

onLoad() {

let params = {

username: this.data.username,

pwd: this.data.pwd

}

// 登录

getLogin(params).then(res => {

wx.setStorageSync('Cookie', res.cookies[0])

wx.switchTab({

url: '../index/index'

})

})

},

// 退出登录

handleLogOut() {

wx.clearStorageSync()

wx.navigateTo({

url: '../login/login'

})

},

})

相关推荐
码出钞能力1 分钟前
linux内核模块的查看
linux·运维·服务器
一渊之隔26 分钟前
微信小程序在用户拒绝授权后无法使用wx.opensetting再次获取定位授权
微信小程序·小程序
雪碧聊技术40 分钟前
深入解析Vue中v-model的双向绑定实现原理
前端·javascript·vue.js·v-model
打不着的大喇叭1 小时前
uniapp的光标跟随和打字机效果
前端·javascript·uni-app
Sun_light2 小时前
6个你必须掌握的「React Hooks」实用技巧✨
前端·javascript·react.js
爱学习的茄子2 小时前
深度解析JavaScript中的call方法实现:从原理到手写实现的完整指南
前端·javascript·面试
百锦再2 小时前
重新学习Vue中的按键监听和鼠标监听
javascript·vue.js·vue·计算机外设·click·up·down
优雅永不过时_v2 小时前
基于vite适用于 vue和 react 的Three.js低代码与Ai结合编辑器
前端·javascript
小皮侠2 小时前
nginx的使用
java·运维·服务器·前端·git·nginx·github
WildBlue2 小时前
🧊 HTML5 王者对象 Blob - 二进制世界的魔法沙漏
前端·javascript·html