La idea principal:
realizar el empalme de interfaces: dividido en empalme de "interfaz fija" y empalme de "interfaz libre"
Cómo realizar el empalme de interfaz: dividido en tres empalmes:
1. Cree un env.js y escriba su propia dirección de interfaz predeterminada Defina algunas interfaces para configurar otros entornos,
por ejemplo: baseUrl: "https://api.it120.cc"
2. Cree un request.js, puede establecer algo de su propia configuración predeterminada en él,
por ejemplo: const subName = ' establecer a voluntad para ver qué tipo de demanda es '
let _url = ${baseUrl}/${isDoMain?subName:''}${url}
3. crear una interfaz api frente a la costura dentro de la interfaz y agregar la interfaz a la dirección de la empresa, y puede aceptar los parámetros pasados en este archivo dentro,
por ejemplo: // Lista de bienes
getList: () => { solicitud de devolución ("/ tienda / bienes / lista", "", {}, verdadero) }, el código principal es el siguiente: env.js
module.exports={
//开发环境url
dev:{
baseUrl:"http://localhost:3000"
},
//测试环境得url
test:{
baseUrl:"http://www.test.com"
},
// 线上环境url
prod:{
baseUrl:"https://api.it120.cc"
}
}
request.js
const {baseUrl} = require("./env").prod
const subName = '随意配置的'
module.exports={
request:(url,method="GET",data={},isDoMain)=>{
wx.showLoading()
let _url = `${baseUrl}/${isDoMain?subName:''}${url}`
return new Promise((resolve,reject)=>{
wx.request({
url: _url,
data:data,
method:method,
header:{
'content-type':'application/x-www-form-urlencoded'
},
success:res=>{
let {code} = res.data
if(code===0||code===700){
resolve(res);
wx.hideLoading()
}else{
wx.showToast({
title: '请先登录',
icon:'none'
})
}
},
fail:res=>{
reject('接口有误请检查')
}
})
})
}
}
archivo principal de la interfaz de configuración api.js
const {request} = require("./request")
module.exports={
// 商品列表
getList:()=>{
return request("/shop/goods/list","",{},true)
},
// 详情页
getDetail:(id)=>{
return request("/shop/goods/detail","",{id},true) // 需要传递参数的
},
}
¿Como llamar?
const {getList,getDetaill} = require("../../http/api")
¿cómo utilizar?
getList().then((res)=>{
console.log(res.data.data) // 获取的数据
this.setData({
list:res.data.data
}) // 把获取到的数据进行更新
})
¿Ginseng?
por ejemplo: let token = wx.getStorageSync ('token')
getList (token). then ((res) => {})
Pase los parámetros al llamar al método y acéptelos en el archivo api.js