首页
学习
活动
专区
圈层
工具
发布

Angular2 之 Promise vs Observable

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

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

    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

    7.6K10

    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库的丰富,但是基础方法都有,实用性较强,在解决异步问题时

    1.4K50

    Angular JSONP 详解

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

    3.1K41

    Angular 与 rxjs 中 take(1) 的运用解析

    对于一些 Angular 服务中调用 HTTP 请求的场景,HttpClient 返回的是一个 Observable 对象,该对象在成功返回数据后便无需继续监听数据流。...例如,在使用 Angular 内置 HttpClient 发起 HTTP GET 请求时,返回的 Observable 会在成功获取数据后发出一个响应数据。...以下是一个更加贴近实际业务场景的代码示例,展示了如何在 Angular 服务中调用 HttpClient,并使用 take(1) 处理一次性 HTTP 请求:import { Injectable }...from `@angular/core`;import { HttpClient } from `@angular/common/http`;import { Observable } from `rxjs...组件在 ngOnInit 生命周期钩子中订阅该 Observable,当 HTTP 请求成功返回数据后,订阅将被自动结束,不会再有额外的监听行为。

    67900

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

    冷热Observable 冷Observable从被订阅时就发出整个值序列 热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( )操作符将一个可观测对象转换为热

    8.1K20

    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

    15.4K120

    Angular 应用中手动调用 subscribe 方法的时机与实践探讨

    在 Angular 应用开发过程中 Observable 扮演着处理异步操作与数据流的关键角色 RxJS 为 Angular 提供了丰富的操作符与工具链 开发者在编写业务逻辑时 往往会面临 Observable...中 HttpClient 模块返回的 Observable 实例默认是冷 Observable 只有在订阅后才会真正发起 HTTP 请求 在需要调用外部 API 或后端服务时 开发者常常需要手动调用...所带来的便利与必要性 在此场景中 HttpClient 返回的 Observable 是冷 Observable 只有在订阅后才会执行 HTTP 请求 开发者通过手动调用 subscribe 方法对数据进行响应处理与错误捕捉...的回调函数分别进行定义与处理 这种精细化控制有助于实现复杂业务场景下的数据交互与状态管理Angular 应用中 服务与组件之间的数据通信有时借助 Subject 或 BehaviorSubject 实现...的执行机制与 Angular 生命周期的关系 在组件与服务中对订阅进行合理的管理 才能构建出既健壮又高效的应用程序 这种实践经验经过大量项目检验 已被业界广泛认同与应用本文通过 HttpClient

    44510
    领券