- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我是响应式(Reactive)编程的新手,阅读所有这些我无法理解的文章有点迷茫。
实际上,我是一名来自 Nodejs、Angularjs、Angular 2 和 React 的 javascript 开发人员。
我做什么
我一直使用 promises,用于远程数据获取、本地异步解析等......比回调更好的可测试性,满足我的需求。
我对流的理解
除非在特定情况下,否则我不知道流可以在哪里拯救我。
这种特殊情况是,我不能在监听流时使用 promise,因为 promise 只会被解析一次。
SocketIo 示例:
io.on('connection', (socket) => {
// this works
});
io.on('connection').then((socket) => {
// this can't work, promise would be resolved only once
});
如果我没记错的话,我可以使用 react 流通过简单地返回一个可观察对象来管理这种情况。对吧?
我不明白的地方
我正在研究 Angular 2 和周围的所有东西。实际上,从许多博客中,人们习惯使用可观察对象来获取远程数据,我不明白使用它而不是 promise 的优势是什么。
事实上,在这两种情况下我都需要制作一个 Remote ,那么为什么一个比另一个多呢?这是性能问题吗?
我需要什么
如果您已经阅读了整个问题,我需要了解的是在远程数据获取的情况下使用响应式(Reactive)编程而不是 promise 的优势是什么?
在哪些情况下(其他情况下)使用响应式的东西比通常的东西更好?
最佳答案
@Günter 为您介绍了 observables 的基础知识,尤其是调用 promises 的能力。
更进一步,我认为可观察对象的关键优势是能够使用运算符构建异步数据流/流。
以下是一些具体的用例:
debounceTime
/switchMap
。当您想利用表单输入根据相应的 HTTP 请求过滤列表时,您需要为请求使用的值是用户完成写入时的值。没有必要发送多个请求:每个新字符一个(一个用于“s”,一个用于“so”,一个用于“som”,...,一个用于“要搜索的东西”)。 debounceTime
运算符通过缓冲事件并在一段时间不活动后提供最后一个事件来实现这一点。
这是一个示例:
@Component({
(...)
template: `
<input [ngFormControl]="ctrl"/>
`
})
export class MyComponent {
constructor() {
this.ctrl = new Control();
this.ctrl.valueChanges
.debounceTime(500)
.distinctUntilChanged()
.switchMap((vallue: string) => {
// Get data according to the filled value
return this.service.getData(entry);
})
.subscribe(data => {
// Update the linked list
this.list = data;
});
}
}
如果您只使用 switchMap
,您将对每个输入有一个请求,但之前正在进行的请求将被取消。这使您可以获得正确的结果,尤其是在某些请求的请求执行时间较长的情况下。
在这种情况下,您可以将来自 Web UI 的事件(DOM 事件)链接到 HTTP 请求以相应地执行(对事件使用react)并应用一些高级行为。
实现重试。通过混合使用 retryWhen
、delay
和 timeout
运算符,您可以轻松(透明地)实现重试
searchPlaces(searchText:string) {
var params = new URLSearchParams();
params.set('placename_startsWith', searchText);
params.set('username', 'templth');
return this.http.get('http://api.geonames.org/postalCodeSearchJSON',
{ search: params })
.retryWhen(error => error.delay(500))
.timeout(2000, return new Error('delay exceeded'))
.map(res => res.json().postalCodes);
}
我认为这是可观察对象的真正力量:异步处理链/数据流和基于事件链接应用程序的不同部分。这是 promises 无法做到的事情,允许实现用例以使您的应用程序更加健壮。
这里有一系列文章可以为您提供更多详细信息:
关于javascript - 使用 Javascript 进行响应式编程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35981941/
我正在尝试检查 Entry 中是否存在重复项,并使用内联消息提醒用户该数字存在。 $(document).ready(function(){ $("#con1").blur(function(
我有一个基于类的 View 。我在引导模式上使用 Ajax。为了避免页面刷新,我想使用此类基于 View 返回 JSON 响应而不是 HTTP 响应,但我只看到了如何为基于函数的 View 返回 JS
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我有一个大型内部企业基于 Web 的应用程序在 IIS6 上运行 ASP.NET 3.5,生成 401 个“未经授权”响应,然后是 200 个“Ok”响应(如 Fiddler 所述)。我知道为什么会发
感谢您研究我的问题。 我有一个node/express服务器,配置了一个server.js文件,它调用urls.js,而urls.js又调用 Controller 来处理http请求,所有这些都配置相
当我使用以下命令时,我得到正确的 JSON 响应: $ curl --data "regno=&dob=&mobile=" https://vitacademics-rel.herokuapp.co
我有一个非常简单的 RESTful 服务,它通过 POST 接收一些表单数据,其目的是在云存储(Amazon S3、Azure Blob 存储等)中简单地保留文本主体(具有唯一 ID)作为一个文件..
UDP 不发送任何 ack,但它会发送任何响应吗? 我已经设置了客户端服务器UDP程序。如果我让客户端向不存在的服务器发送数据,那么客户端会收到任何响应吗? 我的假设是; 客户端 --> 广播服务器地
我有一个电梯项目,其中 有一个扩展 RestHelper 的类,看起来像这样 serve{ "api" / "mystuff" prefix { case a
我们正在寻求覆盖 Kong 错误响应结构并编写自定义消息(即用我们的自定义消息替换“超出 API 速率限制”、“无效的身份验证凭据”等)。 我们要找的错误响应结构(代码是自定义的内部错误代码,与HTT
我正在尝试监听 EKEventStoreChangedNotification 以检查当我的应用程序处于后台时日历是否已更改。 我在 View Controller 的 initWithNibMeth
我了解 javascript,并且正在学习 ASP.NET C# 我想要做什么(完成的是javascript): document.getElementById('divID-1'
是否可以过滤所有 har 对象并仅获取 POST 请求/响应?也许在初始化 BrowserMobProxyServer 期间是这样做的方法?我需要将 har 对象保存到文件中并上传到 har 查看器。
我正在尝试向 Oauth 的 API 发送响应。遗憾的是,Symfony2 文档在解释 $response->headers->set(...); 的所有不同部分方面做得很差。 这是我的 OauthC
我正在尝试测试用例来模拟 api 调用,并使用 python 响应来模拟 api 调用。 下面是我的模拟, with responses.RequestsMock() as rsps: url
在尝试在 Haskell 中进行一些领域驱动设计时,我发现自己遇到了这个问题: data FetchAccessories = FetchAccessories data AccessoriesRes
我正在与 ANT+ USB 棒连接,并用项目 react 器替换我自己天真的“MessageBus”,因为它看起来非常合适。 USB接口(interface)本质上是异步的(单独的输入/输出管道),我
我正在将项目迁移到AFNetworking 2.0。使用AFNetworking 1.0时,我编写了代码来记录控制台中的每个请求/响应。这是代码: -(AFHTTPRequestOperation *
我有以下代码段。 ajaxRequest.onreadystatechange = function(){ if(ajaxRequest.readyState == 4){
我有问题......我在 php 中有一个监听器脚本可以执行以下操作: if ($count != 1) {echo 'no';} else { echo "yes";} 因此它会回显"is"或“
我是一名优秀的程序员,十分优秀!