【问题标题】:Angular 2 Updating objects in “real time.”Angular 2 “实时”更新对象。
【发布时间】:2016-08-28 14:59:14
【问题描述】:

您好,我想总结一下如何更新表格 angular 2。

这是我所拥有的: 后端:快递/MongoDB。更新通过外部应用程序输入数据库 数据:90% 的数据将是静态的。每秒更新 10% 的数据。

我看过 Observables / promises。 HTTP 请求/套接字 IO,但我无法理解这些概念。

主要问题:我可以使用带有 socket.io 的 observables 来更新记录吗?

关于数据更新的其他问题

  1. Angular 2 的 Observables – 是否仅在客户端拉取数据时才使用 observables?或者您可以在将数据推送到客户端时将其与套接字一起使用。 (所有在线示例都使用带有 http 请求的 observables)
  2. 您可以使用 Socket IO 来更新对象还是仅用于新对象?每个示例都是一个聊天应用程序。
  3. 使用 http 请求时,如何设置请求数据的频率? (一些在线示例使用循环,但这似乎是错误的。)

【问题讨论】:

    标签: socket.io angular httprequest observable


    【解决方案1】:
    1. Observables 是基于事件的,因此它们可以用来接收来自服务器的事件,利用 Web 套接字。看看这篇文章(“基于事件的支持”部分):

    2. 实际上它是新对象,但您可以利用 scan 运算符来聚合多个事件的内容。

      var obs = (...)
      obs.startWith([])
         .scan((acc,value) => acc.concat(value))
         .subscribe((data) => {
           console.log(data);
         });
      

      查看这个问题了解更多详情:

    3. 如果要按时间间隔拉取,可以利用interval 方法:

      Observable.interval(3000).flatMap(() => {
        return this.http.get('/some-request').map(res => res.json());
      }).subscribe((data) => {
        console.log(data);
      });
      

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-04-09
      • 2017-11-09
      • 1970-01-01
      • 2018-01-04
      • 2017-09-05
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多