前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Thinking--函数同时支持 callback & promise

Thinking--函数同时支持 callback & promise

作者头像
奋飛
发布2021-08-30 10:15:32
5560
发布2021-08-30 10:15:32
举报
文章被收录于专栏:Super 前端

Thinking系列,旨在利用10分钟的时间传达一种可落地的编程思想。

代码语言:javascript
复制
function fn (cb?: Function, ctx?: Object) {
  // 函数内部逻辑
  console.log('...')
  // promise
  if (!cb && typeof Promise !== 'undefined') {
    return new Promise(resolve => {
      resolve(ctx)
    })
  }
  // callback
  if (cb) {
  	cb.call(ctx)
  }
}

callback 调用

代码语言:javascript
复制
fn(() => console.log('callback')) 	// ... => callback

Promise 调用

代码语言:javascript
复制
fn().then(() => {
	console.log('promise resolve')	// ... => promise resolve
})

async…await 调用

代码语言:javascript
复制
(async function () {
  await fn()
  console.log('async...await')		// ... => async...await
})()
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档