promise使用实例

//这是旧版回调写法
// function moveTo(el,x,y,cb){
//     el.style.transform = `translate(${x}px,${y}px)`
//     setTimeout(function(){
//         cb && cb()
//     },1000)
// }

// let el = document.querySelector('div')

// document.querySelector('button').addEventListener('click',(e) =>{
//     moveTo(el,100,100,function(){
//         console.log('1')
//     })
// })

//promise
function moveTo(el,x,y){
    return new Promise((resolve, reject) => {
    el.style.transform = `translate(${x}px,${y}px)`
    setTimeout(function(){
        resolve()
    },1000)
    }) 
}
    let el = document.querySelector('div')

    // document.querySelector('button').addEventListener('click',(e) =>{
    //     moveTo(el,100,100).then(function(){
    //         return moveTo(el,200,200).then(function(){
    //             return moveTo(el,300,300)
    //         })           
    //     })
    // })
    document.querySelector('button').addEventListener('click',(e) =>{
        moveTo(el,100,100).then(function(){
            moveTo(el,200,200).then(function(){
                moveTo(el,300,300).then(function(){
                    moveTo(el,0,0)
                })
            })           
        })
    })

在回调函数中先return一个promise,下面的then指的就是reslove(),then要和promise配合

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值