【TS】promise代替回调函数使用

参考:

https://blog.csdn.net/a42626423/article/details/135101768

https://blog.csdn.net/a42626423/article/details/135101768

typescript 复制代码
    fun() {
        return new Promise((resolve, reject) => {
            let succ = Math.random() > 0.5
            setTimeout(() => {
                if (succ) {
                    resolve(null)
                }
                else {
                    reject(null)
                }
            }, 2000)
        });
    }


    test() {
        this.fun().then((data) => {
            //成功处理resolve
        }, (data) => {
            //失败处理reject
        })
        //或者

        this.fun().then((data) => {
            //成功处理
        }).catch((error: Error) => {
            //失败处理
        })
    }
    
    //加载多个
    fun2() {
        let loadArr = []
        return new Promise((resolve, reject) => {
            Promise.all(loadArr).then(() => {
                //loadArr都执行完之后
                resolve(null);
            }).catch((error: Error) => {
                //loadArr出错
                resolve(null);
            })
        });
    }

    //链式调用
    test2() {
        let p = new Promise(resolve => {
            setTimeout(() => {
                resolve("success 1")
            }, 2000)
        })

        p.then((info) => {
            // 此处继续返回一个promise对象,形成链式调用
            return new Promise(resolve => {
                console.log("info = ", info)
                setTimeout(() => {
                    resolve("success 2")
                }, 2000)
            })
        }).then((info) => {
            console.log("info = ", info)
        }).catch((error: Error) => {
            //失败处理
        })
    }
相关推荐
敲敲敲敲暴你脑袋1 小时前
从零开始用Canvas画一个2D地图
typescript·数据可视化·canvas
爱的叹息5 小时前
容器初始化Spring Boot项目原理,即web项目(war)包涉及相关类对比详解
前端·vue.js·typescript
阿豪啊6 小时前
TypeScript 中any 和 unknown的区别
typescript
weixin_7488770019 小时前
【在Node.js项目中引入TypeScript:提高开发效率及框架选型指南】
javascript·typescript·node.js
去伪存真1 天前
看我如何破解api接口文档定义空白, 还不想手动写接口TS类型定义的困局
前端·typescript
BillKu1 天前
Vue3 + TypeScript 的 Hooks 实用示例
前端·vue.js·typescript
Joet1 天前
elementPlus_upload组件二次封装,cos上传
vue.js·typescript
菜鸟una1 天前
【Taro3.x + Vue3】搭建微信小程序
前端·vue.js·typescript·taro
kurcp1 天前
vue3 antdesign上传解析excel
前端·typescript·excel
前端_yu小白2 天前
js异步机制
前端·javascript·async·promise·await·js异步·回调地狱