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

方式一:

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'

})

},

})

相关推荐
Smile_Gently2 小时前
前端:最简单封装nmp插件(组件)过程。
前端·javascript·vue.js·elementui·vue
nihui1237 小时前
Uniapp 实现顶部标签页切换功能?
javascript·vue.js·uni-app
陈译8 小时前
Grafana——如何迁移Grafana到一台新服务器
运维·服务器·grafana
尚学教辅学习资料8 小时前
基于SpringBoot的图书借阅小程序+LW参考示例
spring boot·后端·小程序·java毕设·图书借阅
wangjun51598 小时前
linux redis ipv6、ipv4 只接收本地访问、接收本地和远程访问
linux·运维·服务器
x66ccff8 小时前
【nvidia】NCCL禁用P2P后果权衡
服务器·网络协议·p2p
luckycoke8 小时前
小程序立体轮播
前端·css·小程序
一 乐8 小时前
高校体育场管理系统系统|体育场管理系统小程序设计与实现(源码+数据库+文档)
前端·javascript·数据库·spring boot·高校体育馆系统
shengmeshi8 小时前
vue3项目img标签动态设置src,提示:ReferenceError: require is not defined
javascript·vue.js·ecmascript
BillKu8 小时前
vue3中<el-table-column>状态的显示
javascript·vue.js·elementui