uniapp:使用Promise简化回调
uniapp:使用Promise简化回调
promisify.js
因为异步api都是success和fail的形式,所以封装方法:
export const promisify = (api) => {
return (options, ...params) => {
return new Promise((resolve, reject) => {
api(Object.assign({}, options, {
success: resolve,
fail: reject
}), ...params);
});
}
}
为简化之前
uni.getUserProfile({
success: res => {
console.log(res)
},
fail: res => {
},
complete:()=>{
}
})
使用上面的promisify.js
简化后:
import {promisify} from './promisify.js'
const getSystemInfo = promisify(uni.getSystemInfo)
getUserProfile({
desc: "获取你的昵称、头像、地区及性别",
}).then((res)=>{
console.log(res.userInfo)
}).catch((err)=>{
console.log('拒绝授权')
}).finally(()=>{
console.log('拒绝或授权都会执行')
})
因为uniapp中多很多少异步方法,这样一个一个转换不方便const getSystemInfo = promisify(uni.getSystemInfo)
因此批量转换(promisify.js)
export const promisify = (api) => {
return (options, ...params) => {
return new Promise((resolve, reject) => {
api(Object.assign({}, options, {
success: resolve,
fail: reject
}), ...params);
});
}
}
export const toAPromise = (...names) => {
return (names || [])
.map(name => ({
name,
member: uni[name]
}))
.filter(t => typeof t.member === "function")
.reduce((r, t) => {
r[t.name] = promisify(uni[t.name]);
return r;
}, {});
}
export const unip = toAPromise('getSystemInfo','getUserProfile','login','showToast');
使用
import {unip} from '@/common/js/promisify.js'
unip.getUserProfile({
desc: "获取你的昵称、头像、地区及性别",
}).then((res) => {
console.log(res.userInfo)
}).catch((err) => {
unip.showToast({
title: "拒绝了授权",
icon: "none"
})
}).finally(() => {
console.log('拒绝或授权都会执行')
})
- 多个嵌套可用async/await
作者:黄哈哈。
原文链接:https://www.cnblogs.com/jiajia-hjj/p/14705303.html
本博客大多为学习笔记或读书笔记,本文如对您有帮助,还请多推荐下此文,如有错误欢迎指正。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端