- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
由于我的代码很长,我将用一个简化的例子来解释我的问题。
我想在 isFetching
或 isDownloading
之一为真时显示某个 div。
<div *ngIf="(isFetching || isDownloading)">
My div element is here
</div>
在我的程序开始时,它们都是真的,所以应该显示 div。在上面的 div 下方,我还有其他元素,这些元素在 isFetching
更改为 false
后显示在 View 中。 (isFetching
在从数据库中获取完成后更改为 false
。)在 isFetching
更改为 false
之后并呈现元素,在下载这些元素的最后一个元素(它是图像)后,我将 isDownloading
更改为 false
。
当isFetching
和isDownloading
都为false时,这就是我要隐藏div元素的时候。
但是,我刚才解释的代码给我这个错误:
Expression has changed after it was checked. Previous value: 'ngIf: true'. Current value: 'ngIf: false'.
我似乎不明白为什么会出现此问题?我的逻辑有什么问题?如何在不出现此错误的情况下获得预期的结果?
编辑:
这段代码在我的类的构造函数中:
firebase.database().ref('/users/' + this.userId).once('value').then(function(snapshot) {
this.username = (snapshot.val() && snapshot.val().username) || 'Anonymous';
this.isFetching = false;
});
isFetching
更改为false
后。我的 .html 中还有其他元素被渲染。然后在加载这些元素的最后一个元素(图像)后调用此代码 (load)="latestElementLoaded()"
。
latestElementLoaded(){
this.isDownloading = false;
}
最佳答案
您可能需要考虑另一种模式,使用可观察对象,它可以简化您的代码(AngularFire 值得研究):
this.data$ = this.angularFirestore.doc('some/path').valueChanges();
这会将您的数据作为可观察对象获取(这只是演示代码——请检查实际语法)。将它放在 ngOnInit
中,而不是构造函数中。不要乱用 .once
或快照或其他样板文件。
现在,在你的模板中,你可以写
<div *ngIf="data$ | async as data; else notFetched">
Data is {{data | json}}
<ng-template #notFetched>Data is not fetched yet..wait...</ng-template>
</div>
这完全消除了对 isFetching
类标志的需求。
关于您的代码:
firebase.database().ref('/users/' + this.userId).once('value').then(function(snapshot) {
this.username = (snapshot.val() && snapshot.val().username) || 'Anonymous';
this.isFetching = false;
});
我完全不知道它是如何工作的,因为回调函数 (function(snapshot)
) 中的 this
可能是未定义的,给你一个运行时错误。
我不是 Angular 内部专家,但我怀疑导致您报告的错误的原因是以下事件序列:
ngOnInit
并检查检测到的变化变量。 isFetching
此时仍然为真。这整个问题是由于将 firebase 查询逻辑放在构造函数中引起的,如评论中所述。构造函数应严格限于基本初始化。它们不应该包含业务逻辑,绝对不应该包含异步的东西。
关于angular - ngIf 表达式检查后发生了变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51580362/
这个问题是关于理解为什么一种技术比另一种更好。在 Angular 4/5 中,在模板中,您可以通过执行以下操作来实现相同的目的: 1) *ngIf-else 语法 content here
我的 *ngIf 在一个特定变量 isAdmin 上遇到了一个奇怪的问题(这应该允许我在 userList 中显示用户列表)。我不确定为什么它的行为与同一组件中的所有其他 *ngIf 语句不同。 这是
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
我有一个自定义选项卡实现,其中我使用一些 ngIf 指令显示选项卡内容,如下所示: 选项卡有自己的形式,一些内容应该只初始化一次,不能再初始化。在我当前的实现中,每次我更改条件然后更改选项卡时,组
我的问题涉及 *ngif 指令,一次 *ngif=true 我希望在我的“ModClass”指令执行其操作之前首先呈现 html 内容。 我尝试实现 ngOnInit 和 ngViewInit 但没有
基本上,我有一个带有 *ngIf 条件的 div,但我在这个 div 中也有一个 img。这是一个登录页面,我想为不同类型的用户显示不同的登录页面。这就是我使用 ngIf 的原因。但是,直到我单击用户
我正在使用 Angular 6。 我有一个如下所示的 html。 此处,showMenus 默认为 false,并在单击同一页面中的按钮时将其设置为 true。 现在,我试图在将 show
演示: https://stackblitz.com/angular/mxoemeygmlk?file=app%2Ftable-http-example.ts 解决这个 Angular 误差的最佳解决
我正在使用 AngularDart,我需要根据 bool 值 registerDisplay 显示和隐藏组件。尝试使用 *ngIf ,但抛出错误。以下是 html。 app_component.htm
在一个组件中,我有一个与此类似的源代码: {{row.job_id}} Job ID Not available 我想在单个 ng-template 中使用
直接来自 angular.io 的示例对我不起作用: {{show ? 'hide' : 'show'}} show = {{show}} Text to show Alternate text w
我的观察是否正确,即使 *ngIf 宿主元素不在 DOM 中,它也在内存/堆中。因此它正在创建宿主元素但不将其附加到 DOM。 我在上面是因为我有一个巨大的列表。每个列表元素中都有一些 *ngIfs。
我有一段这样的代码 ng-show="!edit{{id}} && imageUrl" 但这似乎行不通。在哪里 ng-show="!edit1 && imageUrl" 有效。语法有问题吗?? 实际的
所以我试图更好地理解 Angulars ChangeDetection 并无意中遇到了一个问题: https://plnkr.co/edit/M8d6FhmDhGWIvSWNVpPm?p=previe
以下是一个 HTML 代码片段,其中 ngIf 检查 forceAngle 是否为真,默认情况下 forceAngle 为假。单击按钮后,我将调用 ForceAngles() 函数并将 forceAn
我有一个从多个地方调用的登录组件,并有一个输入将其显示为模态组件或只是普通组件。 登录组件: declare var jQuery: any; @Component({ selector: '
我正在使用 new Angular local variable assignment feature在 ngIf 下的子元素中引用异步管道的结果: 1"> There's more
我有一个 observable,我想在 ngIf 中创建一个变量,并且仅在值为 null 时返回 false(该 observable 返回一个数字) 我需要明确检查 null 因为我的 observ
我有一个组件 我只想显示是否设置了其属性之一。所以我想在做这样的事情: ... 事情是组件是在 HTML DOM 中创建的。所以,为了避免它的创建,我的假设是我应该把 * ngIf 在
当在 *ngIf 中使用 AsyncPipe 时,如果连接到 AsyncPipe 的 Observable 推送其*ngIf 变为真之前的值,从 AsyncPipe 返回的值将不正确。 例如,假设我有
我是一名优秀的程序员,十分优秀!