ionic2页面回传值,关于Typescript的Promise承诺

刚入门,没深究~  -。-

经典:javascript Promise介绍 来自谷歌的说明,简单直观

ionic2页面回传值,关于Typescript的Promise承诺_第1张图片
来自谷歌

Promise 构造函数接受一个函数作为参数,该函数的两个参数分别是 resolve 方法和 reject 方法。如果异步操作成功,则用 resolve 方法将 Promise 对象的状态,从「未完成」变为「成功」(即从 pending 变为 resolved);如果异步操作失败,则用 reject 方法将 Promise 对象的状态,从「未完成」变为「失败」(即从 pending 变为 rejected)。


ionic2页面回传值,关于Typescript的Promise承诺_第2张图片
来自谷歌

then()有两个参数,一个成功案例的回调,另一个是失败的情况。两者都是可选的,因此您可以为成功或失败的情况添加回调。


ionic2页面回传值,关于Typescript的Promise承诺_第3张图片
来自谷歌


ionic2页面回传值,关于Typescript的Promise承诺_第4张图片
来自谷歌

这是一个很好的例子,如果能够获取到对应url的xml请求,则req.status=200,在if中可以执行你想做出的操作,并执行resolve(req.response),其中req.response是请求得到的结果,如果找不到则返回req.status=404,并reject()返回错误。

在ionic2中,页面回传值的方法:

同上所描述那般

做出一个承诺


ionic2页面回传值,关于Typescript的Promise承诺_第5张图片
来自tc

将该方法作为一个参数传入push的页面中

注意:最开始我本来是采用如下图方式的,但是很不幸,出现了问题,问题所在就是关于这个this的作用域问题。这里要用到ES6的箭头函数 Arrow Functions。普通function函数和箭头函数的行为有一个微妙的区别,箭头函数没有它自己的this值,箭头函数内的this值继承自外围作用域。


ionic2页面回传值,关于Typescript的Promise承诺_第6张图片
来自tc

回传值,将需要传过去的指丢入contactsCallback中,即将数据从该页面传到上一个页面中,并且then后,通过是执行了resolve()还是reject()来识别是否成功,如果成功,pop掉当前页面,否则输出错误。

ionic2页面回传值,关于Typescript的Promise承诺_第7张图片
来自tc



参考文章:JavaScript进阶之路——认识和使用Promise,重构你的Js代码 了解Promise

一直以来,JavaScript处理异步都是以callback的方式。近几年随着JavaScript开发模式的逐渐成熟,CommonJS规范顺势而生,其中就包括提出了Promise规范,Promise完全改变了js异步编程的写法,让异步编程变得十分的易于理解。

1.什么是Promise

所谓Promise,字面上可以理解为“承诺”,就是说A调用B,B返回一个“承诺”给A,然后A就可以在写计划的时候这么写:当B返回结果给我的时候,A执行方案S1,反之如果B因为什么原因没有给到A想要的结果,那么A执行应急方案S2,这样一来,所有的潜在风险都在A的可控范围之内了。

Promise规范如下:

一个promise可能有三种状态:等待(pending)、已完成(fulfilled)、已拒绝(rejected)

一个promise的状态只可能从“等待”转到“完成”态或者“拒绝”态,不能逆向转换,同时“完成”态和“拒绝”态不能相互转换

promise必须实现then方法(可以说,then就是promise的核心),而且then必须返回一个promise,同一个promise的then可以调用多次,并且回调的执行顺序跟它们被定义时的顺序一致

then方法接受两个参数,第一个参数是成功时的回调,在promise由“等待”态转换到“完成”态时调用,另一个是失败时的回调,在promise由“等待”态转换到“拒绝”态时调用。同时,then可以接受另一个promise传入,也接受一个“类then”的对象或方法,即thenable对象。

你可能感兴趣的:(ionic2页面回传值,关于Typescript的Promise承诺)