取消请求 的例子

本文介绍了如何使用JavaScript创建一个可取消的延迟任务,通过cancellableDelayedResolve函数实现延迟执行并能根据用户操作灵活取消。涉及Promise、CancelToken和前端事件监听。
摘要由CSDN通过智能技术生成

test = (flag) => {
    class CancelToken {
        constructor(cancelFn) {
            this.promise = new Promise((resolve, reject) => {
                cancelFn(() => {
                    setTimeout(console.log, 0, "delay cancelled"); resolve();
                })
            })
        }
    }

    const startButton = document.querySelector('#start');
    const cancelButton = document.querySelector('#cancel');

    function cancellableDelayedResolve(delay) {
        setTimeout(console.log, 0, "set delay");
        return new Promise((resolve, reject) => { 
            const id = setTimeout((() => {
                setTimeout(console.log, 0, "delayed resolve");
                resolve();
            }), delay);
            const cancelToken = new CancelToken(
                // (cancelCallback) => cancelButton.addEventListener("click", cancelCallback)
                (cancelCallback) => {
                    console.log(cancelCallback)
                }
            );
            cancelToken.promise.then(() => clearTimeout(id));
        });
    }

    startButton.addEventListener("click", () => cancellableDelayedResolve(1000));
}

cancelRequest = () => {
    new Promise((resolve, reject) => {
        console.log("已经开始发请求啦");
        setTimeout(() => {
            resolve();
        }, 8000)
    })
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值