首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

typeScript版仿Promise源码

作为一个前端, 还有人说不会用 Promise,真的就有点过分了. 为了跟上卷的潮流,我们今天就用typeScript 来实现一下 Promise 的实现....*写 promise 之前我们需要明确一些常识....必须是一个构造函数或是类(我们在使用时必须 new, js中 类实际即时构造函数的语法糖) promise 有三个状态 padding(等待) fulfilled(完成) reject(异常...) promise 状态一旦改变就冻结, 不再发生改变 支持链式调用 拥有 all, resolve, reject, race 四个静态方法 下面我们开始进入代码块 // 首先promise 有三个状态...(reason) } } } 以上我们就实现了一个很简单的 Promise, 这个 Promise 很弱, 只能执行同步代码, 也不支持链式调用.显然这样肯定不行的, 大家都知道, Promise

50620
您找到你想要的搜索结果了吗?
是的
没有找到

从C#到TypeScript - Promise

从C#到TypeScript - Promise 背景 相信之前用过JavaScript的朋友都碰到过异步回调地狱(callback hell),N多个回调的嵌套不仅让代码读起来十分困难,维护起来也很不方便...这篇先来看看PromisePromise的特点 Promise之于TypeScript,相当于Task之于C#,只有返回Promise的函数才能使用async await。...Promise的使用 可以直接new一个Promise对象,构造函数的参数是一个有两个参数的函数。...而且Promise的异常是冒泡传递的,最后面写一个catch就可以捕获到前面所有promise可能发生的异常,如果用reject就需要每个都写。...Promise除了用then来顺序执行外,也同样可以不阻塞同时执行多个Promise然后等所有结果返回再进行后续操作。

1.5K80

ES6新增语法(五)——Promise详解

Promise介绍 promise是一个对象,从它可以获取异步操作的消息。有all、race、reject、resolve这几个方法,原型上有then、catch等方法。...状态的缺点: 无法取消Promise,一旦新建它就会立即执行,无法中途取消。 如果不设置回调函数,Promise内部抛出错误,不会反应到外部。...使用语法: let p = new Promise( (resolve,reject)=>{ //resolve 和reject是两个函数 }) p.then( ()=>{}, // 传入的resolve...使用语法Promise.all([ p,p1,p2.... ]).then() 使用实例如下: const p1 = new Promise((resolve,reject)=>{ resolve...Promise的缺点 无法取消Promise,一旦新建就会立即执行,无法暂停和取消。 如果不设置回调函数,Promise内部抛出的错误,不会反应到外部。

41030

ES6新增语法(五)——Promise详解

Promise介绍 promise是一个对象,从它可以获取异步操作的消息。有all、race、reject、resolve这几个方法,原型上有then、catch等方法。...状态的缺点: 无法取消Promise,一旦新建它就会立即执行,无法中途取消。 如果不设置回调函数,Promise内部抛出错误,不会反应到外部。...使用语法: let p = new Promise( (resolve,reject)=>{ //resolve 和reject是两个函数 }) p.then( ()=>{}, // 传入的resolve...使用语法Promise.all([ p,p1,p2.... ]).then() 使用实例如下: const p1 = new Promise((resolve,reject)=>{ resolve(...Promise的缺点 无法取消Promise,一旦新建就会立即执行,无法暂停和取消。 如果不设置回调函数,Promise内部抛出的错误,不会反应到外部。

40210

JavaScript与TypeScript的基础语法对比

在本文中,我们将探讨这两者之间的基础语法对比,并讨论为什么在某些情况下选择使用TypeScript而不是JavaScript。...让我们来看一个简单的例子,展示了JavaScript和TypeScript之间的语法差异:// JavaScriptvar x = 10;let y = "Hello";const z = true;/...为什么选择TypeScript而不是JavaScript?静态类型:TypeScript的最大特点之一就是引入了静态类型。...但对于大型、复杂的项目,使用TypeScript可以提供更好的工具和语言特性,有助于更好地管理代码库。结论JavaScript和TypeScript各有其优势和用途。...在逐渐熟悉两者语法和特性的过程中,开发者可以更灵活地选择适合自己项目的编程语言。我正在参与2024腾讯技术创作特训营第五期有奖征文,快来和我瓜分大奖!

12800

总结TypeScript 的一些知识点:TypeScript 基础语法

TypeScript 基础语法TypeScript 程序由以下几个部分组成:模块函数变量语句和表达式注释第一个 TypeScript 程序我们可以使用以下 TypeScript 程序来输出 "Hello...空白和换行TypeScript 会忽略程序中出现的空格、制表符和换行符。...TypeScript 区分大小写TypeScript 区分大写和小写字符。分号是可选的每行指令都是一段语句,你可以使用分号或不使用, 分号在 TypeScript 中是可选的,建议使用。...TypeScript 支持两种类型的注释单行注释 ( // ) − 在 // 后面的文字都是注释内容。多行注释 (/* */) − 这种注释可以跨越多行。...TypeScript 是一种面向对象的编程语言。面向对象主要有两个概念:对象和类。对象 :对象是类的一个实例(对象不是找个女朋友),有状态和行为。

45610

JavaScript手写PromisePromise.then()、Promise.all()、Promise.race()

我们可以将传给then函数和新Promise的resolve一起push到前一个Promise的callbacks数组中,达到承前启后的效果: 承前:当前一个Promise完成后,调用其resolve变更状态...如果返回的结果是个Promise,则需要等它完成之后再出发新Promise的resolve,所以可在其结果的then里调用新Promise的resolve then(onFulfilled, onReject...这个方法返回一个新的Promise对象 遍历传入的参数,用Promise.resolve()将参数“包一层”,使其变成一个Promise对象 参数所有回调成功才是成功,返回值数组与参数顺序一致 参数数组其中一个失败...,则触发失败状态,第一个触发失败状态的Promise错误信息作为Promise.all的错误信息 function promiseAll(promises){ return new Promise...因为Promise的状态只能改变一次,那么我们只需要把Promise.race中产生的Promise对象的resolve,注入到数组中的每一个Promise实例中的回调函数即可。

93410

【OpenHarmony】TypeScript 语法 ④ ( 函数 | TypeScript 具名函数和匿名函数 | 可选参数 | 剩余参数 | 箭头参数 )

参考文档 : ArkTS开发语言介绍 一、TypeScript 函数 1、TypeScript 具名函数和匿名函数 TypeScript 语言中的 函数语法 与 JavaScript...中 , 必须声明 形参和返回值 类型 ; TypeScript 函数 与 Kotlin 函数 极其相似 ; TypeScript 函数 使用 function 关键字定义 , 在 JavaScript...函数 与 JavaScript 函数对比 TypeScript 函数 与 JavaScript 函数对比 : 唯一区别就是 JavaScript 函数中 , 不允许声明 函数形参 和 返回值 的类型...函数 可选参数 在 TypeScript 函数 的 形参 中 , 形参名称后面 使用 ?...代码 : [LOG]: 2 [LOG]: 8 4、TypeScript 函数 剩余参数 在 TypeScript 函数 函数形参 中 , 还可以使用 " 剩余参数 " , 剩余参数 可以理解为 个数不限的

7610

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券