uniapp:使用Promise简化回调
Published on 2021-04-26 16:31 in 分类: uniapp with 黄哈哈。
分类: uniapp

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

参考:
在微信小程序中使用 async/await

微信小程序:使用Promise简化回调

posted @   黄哈哈。  阅读(2388)  评论(1编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示