- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我用 Dart 编写的 Angular2 应用程序中,我有几个服务可以跟踪在 View 中不一定有任何特定关系的组件之间共享的数据。我需要由任何组件发起的更新反射(reflect)在每个组件的显示中,我想要 OnPush
更改检测的性能优势,我需要组件显示可能在创建组件之前设置的值,并且我希望所有这些都以最少的样板文件来完成。
我的研究表明 Observables 可能是我所需要的,但我无法在几个方面找到明确的答案。
Dart 中是否有与 Angular2 配合良好的 Observable 实现?
Observable 与 Dart Stream 有什么不同吗?特别是 Observable 是否支持获取当前值以及收到有关 future 更新的通知?
最后但同样重要的是,假设 Observable 满足我的要求,声明组件的 Observable String 属性的最小语法是什么,使用从注入(inject)服务检索的 Observable 初始化它,在组件的模板中显示它的值(开始具有预先存在的值),并且更新其值会自动标记组件以进行推送更改检测?
如果 Observable 对此不起作用,我还应该怎么做?我目前的想法是使用自定义 Stream
子类,在新监听器收到的任何其他内容之前插入最新值,并通过 async
管道发送它以处理从中提取值用于更改检测的流和标记。
我的理想解决方案在使用中看起来像这样:
@Injectable()
class MyService {
@observable int health;
}
@Component(
...)
class MyComponent {
@observable int health;
MyComponent(MyService service) : health = service.health;
}
在模板中:
<span>{{health | async}}</span>
或者对于真正理想的情况,尽管这必须以某种方式挂接到 Angular 的模板编译中(也许使用转换器?我还没有了解它们是如何工作的):
<span>{{health}}</span>
仅此而已,它就可以正常工作。
我现在使用的自定义解决方案没有那么方便,但也差不多了。
最佳答案
对于集合和类,您可以使用 https://pub.dartlang.org/packages/observe .它不是专门为与 Angular2 一起使用而设计的,而是为 Polymer <= 0.16.x
而设计的,但它应该与 Angular2 OnPush
一起使用。
如果你让一个集合可观察
List myList = toObservable([]);
您可以订阅更改
myList.changes.listen((record) {
// invoke Angular change detection
});
当类扩展Observable
时(直接或通过应用Observable
mixin)
class Monster extends Unit with Observable {
@observable int health = 100;
void damage(int amount) {
print('$this takes $amount damage!');
health -= amount;
}
toString() => 'Monster with $health hit points';
}
您还可以订阅更改并通知 Angular
var obj = new Monster();
obj.changes.listen((records) {
// invoke Angular change detection
});
注意:如果您有一个包含可观察类实例的可观察集合,您需要分别监听该集合和包含的类。该集合仅报告添加和删除,但不报告包含项的属性更改。
Is an Observable meaningfully different from a Dart Stream? ...
我认为 Dart Observable
与 Stream
的意义不同。 someObservable.changes
返回一个发出变化的 Stream
,但是变化事件是由 Observable
实现和从中生成额外代码的转换器生成的属性上的 @observable
注释。
In particular does an Observable support getting the current value in addition to being notified about future updates?
当您绑定(bind)到可观察对象的属性时,您将获得当前值。当值更改并且 changes
订阅通知这些更改并且您通知 Angular 更改检测已发生更改时,Angular 会将绑定(bind)更新为最新值。
the minimal syntax for declaring an Observable String property of a component,
上面的代码示例显示了一个 int
属性,但在使用 String
时没有区别。
关于dart - 在 Dart 中使用可观察对象进行 Angular2 变化检测,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35879737/
我正在尝试在项目中学习和添加 Angular 国际化。我只能理解 Angular 文档 (https://angular.io/guide/i18n-overview) 的编译时翻译。 我需要这样的东
在我的 Angular 应用程序中,基于登录用户,我想通过显示/隐藏不同的菜单项或允许/禁止某些路由来授予或限制功能。 目前成功登录后,我的 .NET Core API 会返回一个 JWT token
我是 Angular 的新手,目前我已经看过 angular.io 网站提供的一些示例。但是在component decorator在文档中的解释,它指出 Angular components are
这里是service employee-service.service.ts的代码 import { Injectable } from '@angular/core'; import { HttpC
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
如何正确安装 PUG/JADE 到 Angular 2 或更高版本 这样在工作和 AOT 和 JiT 的同时 工作单元和集成测试 并且在创建每个新组件时不会受到太多影响 最佳答案 我看到了很多解决方案
我的 Angular 12 应用程序中有一些通用组件,我计划将其创建为一个 Angular 库,以便其他应用程序也可以使用它。我们有一些应用程序在较低版本的 angular(例如 angular 8/
tl;dr; ng build 删除了包含我编译的自定义库的/dist 文件夹。这会使我项目代码中对该库的所有引用无效,从而导致 ng build 最终失败。我做错了什么? 我关注了documenta
我正在将一些“遗留”(非 typescript )js 库导入到我的 Angular SPA 中。 通常我只是从 cdn 添加一个负载到 index.html 就像: 在 Angular 分量中我只
我有这个 angular 应用程序,它基本上使用了库的概念。 我有 2 个名为 的库Lib1 和 lib2 根据他们所服务的微服务分组。 现在我将这些库导入主应用程序,即 应用1 事情一直到现在。 现
我在我的项目中启用了 angular Universal。我现在想完全删除它。我试图删除以下文件 /server.ts /webpack.server.config.js /src/tsconfig.
我已经有一个 AuthService 在登录时对用户进行身份验证,并且 AuthGuard 在未登录的情况下阻止访问。 某些页面我通过 UserProfile/Role 限制访问,但现在我需要阻止页面
我正在尝试使用 angular、TypeORM、SQLite 和其他组件作为 webpack 构建 Electron 应用程序。 我从在 GitHub 上找到的示例开始我的开发:https://git
我在从 Angular 8 更新到 9 并运行时遇到以下错误 ng 更新@angular/material: Package "@angular/flex-layout" has an incompa
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在我的 h1 元素“之前”创建一个小的程式化三 Angular 形图案,但我无法正确地圆 Angular 。右上角没问题,但其他两个有剪裁问题。 这是输出以及形状的放大图像: 使用的代码如下: h
我有一个 Angular 元素,带有自定义标记名 - fancy-button。如何将 fancy-button 嵌入 Angular 应用程序? 我已经尝试了以下方法,但都没有用 - 在 index
我已将我的项目从 angular 5.2.9 升级到 angular 6.0.0-rc.5。 除了包路径中的几个快速 RxJS 修复外,一切看起来都不错。(此链接非常有用:Want to upgrad
我是一名优秀的程序员,十分优秀!