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

Angular2 之 Promise vs Observable

调用情况 Observable 还具有可订阅性,对于 Cold Observable 而言,只有订阅后才开始起作用 Promise 一经产生便开始起作用 总结:在视频中有详细的介绍。...Observable,由于可以有任意多个数据,因此需要一个额外的状态来表示完成,一经完成后便不能再产生数据。...运算符 Promise ,由于有且只有一个数据,所以无需复杂的操作,仅需要一个简单的变换(返回值)或者组合(返回另一个 Promise)功能即可,甚至还可以把组合变换与使用统一为一个操作,也就是我们的...对于组合,(最简单的方式)需要使用 .mergeMap 方法,用来把两个 Observable 整合为一个 Observable; 对于使用,我们需要使用 .subscribe 方法,用来通知 Observer...当然还可能有另一类运算符,比如 .toPromise 等,这些并不返回 Observable 的方法其实本身并不是一个运算符,仅仅是对 Observable 的原型扩展。

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

Angular 入坑到挖坑 - HTTP 请求概览

对应官方文档地址: Angular HttpClient 配套代码地址:angular-practice/src/http-guide 二、Contents Angular 入坑到弃坑 - Angular...使用入门 Angular 入坑到挖坑 - 组件食用指南 Angular 入坑到挖坑 - 表单控件概览 Angular 入坑到挖坑 - HTTP 请求概览 三、Knowledge Graph ?...constructor(private services: AntiMotivationalQuotesServicesService) { } ngOnInit(): void { } } 4.1.2、服务端获取数据...在处理错误信息的回调方法中,方法返回了一个 HttpErrorResponse 对象来描述错误信息 因为这里的错误更多是服务在与后端进行通信产生的错误,因此对于错误信息的捕获和处理更应该放到服务中进行,...而在组件处仅显示错误提示 在服务中定义一个错误处理器,用来处理与后端请求中发生的错误 import { Injectable } from '@angular/core'; import { Observable

5.2K10

angular 中$q服务介绍

$q $q是angular中一个用来解决JS异步编程的服务,借鉴了 Kris Kowal’s Q 库,可以看作是一个轻量的Q库,遵循 Promises/A+的规范。...API 通过$q.defer()方法构造出一个实例,该实例有三个方法,分别是:resolve/接受promise成功的值,reject/接受promise被拒绝,notify/再一次异步任务中,可能返回多次...在$q.defer()方法构造出的实例中,有一个promise属性,用来返回一个promise对象。 通过then方法,可以实现链式函数,来解决回调地狱的诟病。...var deferredS = $q.defer(); var _that = this; this.searchAfter(deferredA);//进行异步操作的函数,成功后返回...总结 在JS中,解决异步模式问题的方法还有很多,比如回掉函数,事件监听,发布订阅等等,而angular的$q提供了一个轻量的promise库,虽然方法远没有Q库的丰富,但是基础方法都有,实用性较强,在解决异步问题时

99250

Angular JSONP 详解

一、什么是 JSONP JSONP(JSON with Padding)是数据格式JSON的一种 “使用模式”,可以让网页别的网域要数据。另一个解决这个问题的新方法是跨来源资源共享。...利用 script 元素的这个开放策略,网页可以得到其他来源动态产生的 JSON 数据,而这种使用模式就是所谓的 JSONP。...通常我们使用 都是引用的静态资源,其实它也可以用来引用动态资源(php、jsp、aspx 等),后台服务被访问后会返回一个 callback(data) 形式的字符串,由于是字符串,因此在后台的时候不会起到任何作用...,但返回浏览器端,放入 标签之内,就是一个合法的函数调用,实参就是我们所需要的数据。...那是不是我们通过 HttpClient 服务发送的 JSONP 请求被 JsonpInterceptor 拦截器处理了。

2.3K41

angular面试题及答案_angular面试

在传统的web技术中,客户端请求一个web页面(HTML/JSP/asp),服务返回资源(或HTML页面),客户端再次请求另一个页面,服务器用另一个资源响应。...当observable或promise返回data时,我们使用一个临时属性来保存内容。稍后,我们将相同的内容绑定到模板。...Authentication (认证) : 用户登录凭据传递给(服务器上的)认证API。在服务器端验证凭据并返回JSON Web Token(JWT)。...Observer / Observable Observable(可观察者) 接受一个Observer作为参数然后返回unsubscribe函数 – 特征:...ngOnInit : 在angular 第一次显示数据绑定和设置指令、组件的输入属性之后,初始化指令、组件 所以angular的生命周期看,constructor是执行在先的 所以既然ngOnchanges

10.8K120

【响应式编程的思维艺术】 (5)Angular中Rxjs的应用示例

冷热ObservableObservable被订阅时就发出整个值序列 热Observable无论是否被订阅都会发出值,机制类似于javascript事件。...Angular应用中的Http请求 Angular应用中基本HTTP请求的方式: import { Injectable } from '@angular/core'; import { Observable.../message.service';//某个自定义的服务 import { HttpClient, HttpParams, HttpResponse } from '@angular/common/http...使用Rxjs构建Http请求结果的处理管道 3.1 基本示例 尽管看起来Http请求的返回结果是一个可观测对象,但是它却没有map方法,当需要对http请求返回的可观测对象进行操作时,可以使用pipe操作符来实现...,{observe:'response'}); } http请求默认返回一个冷Observable,每当返回的流被订阅时就会触发一个新的http请求,Rxjs中通过shareReplay( )操作符将一个可观测对象转换为热

6.6K20
领券