火力基地可参考退货处理



我正在使用Angularfire2并进行推送调用来存储对象。 它看起来像下面:

单击处理程序

assignCode(){
this.ddlSvc.assignCoupon(this.selItem.key, coupon).then(
(resp) =>  {
console.log("user created with:" + resp)
const alert = this.core.createAlert('Confirmation', 'Coupon Assgined to customer!')
alert.present()
}
)
}

Angular 服务调用 Firebase

assignCoupon(key:string, coupon:Coupon){
return this.db.list('/users/' + key + '/coupons').push(coupon)
}

当调用客户端用户具有推送到此节点所需的权限时,它工作正常。但是,我们正在测试调用客户端没有权限的情况。目前,当我们触发这种情况时,我们会以非常丑陋的方式在 UI 上收到所有错误,而不是一个不错的弹出窗口,因为我们没有处理它。那么,我们如何处理错误部分呢?由于它是一个可随后的引用,因此单击处理程序函数没有.".catch"来处理。

如果你转到ThenableReference的定义(在Visual Studio Code中,你会按Ctrl-T,然后键入ThenableReference(,你应该看到这样的内容:

interface ThenableReference
extends firebase.database.Reference,
PromiseLike<any> {}

我们关心的部分是PromiseLike<any>。 如果你跳到定义,你应该看到这个:

interface PromiseLike<T> {
/**
* Attaches callbacks for the resolution and/or rejection of the Promise.
* @param onfulfilled The callback to execute when the Promise is resolved.
* @param onrejected The callback to execute when the Promise is rejected.
* @returns A Promise for the completion of which ever callback is executed.
*/
then<TResult1 = T, TResult2 = never>(onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null, onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null): PromiseLike<TResult1 | TResult2>;
}

请注意,then接受在发生错误时调用的可选第二个回调。 您应该能够使用它来代替catch方法。

最新更新