- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我一直在开发 Angular 应用程序。我有一个 events.service
,它包含一个方法 getEvents()
,它从我拥有的 Angular Firestore 集合中返回一个类型为 Event
的 Observable。
在我的 homepage.component
中,我的 getEvents()
方法订阅了事件集合的 valueChanges()
,它将集合存储到我的数组 Event
的局部变量。
现在,它工作得很好,订阅也很完美。我在 Firestore 中添加、修改或删除的任何文档都会在我的客户端中实时更新。非常酷的东西。
问题是当我路由到另一个页面,然后导航回我的主页时,我的本地变量是空的!我不知道为什么。
这是我的代码:
app.module.ts
const appRoutes: Routes = [
{ path: "", redirectTo: "/login", pathMatch: "full" },
{ path: "login", component: LoginComponent },
{ path: "signup", component: SignupComponent },
{ path: "home", component: HomepageComponent, canActivate: [AuthGuard] },
{
path: "reservepage/:id",
component: ReservePageComponent
},
{ path: "scan", component: ScanPageComponent },
{ path: "create", component: CreateEventPageComponent },
{ path: "preview/:id", component: PreviewEventPageComponent }
];
event.service.ts
// Angular imports
import { Injectable } from "@angular/core";
// Angular Fire Imports
import {
AngularFirestore,
AngularFirestoreCollection,
AngularFirestoreDocument,
fromDocRef
} from "angularfire2/firestore";
import { AngularFireAuth } from "angularfire2/auth";
import * as firebase from "firebase";
// Internal imports
import { Event } from "./event";
import { AuthService } from "../auth/auth.service";
// rxjs imports
import { Observable, of } from "rxjs";
import { map } from "rxjs/operators";
@Injectable({
providedIn: "root"
})
export class EventsService {
constructor(
private angularFirestore: AngularFirestore,
private authService: AuthService,
private firebaseAuth: AngularFireAuth
) {}
collection: AngularFirestoreCollection<
Event
> = this.angularFirestore.collection("events");
collection$: Observable<Event[]> = this.collection.valueChanges();
document: AngularFirestoreDocument<Event>;
document$: Observable<Event>;
id: string;
add(
_name: string,
_description: string,
_photoURL: string,
_address?: string,
_totalTickets?: number,
_ticketsSold?: number,
_ticketsAvailable?: number
) {
this.collection
.add({
id: "",
name: _name,
description: _description,
photoURL: _photoURL,
uid: this.firebaseAuth.auth.currentUser.uid,
address: _address,
totalTickets: _totalTickets
})
.then(docRef => {
this.collection.doc(docRef.id).update({
id: docRef.id
});
this.setId(docRef.id);
});
}
getEvents(): Observable<Event[]> {
return this.collection$;
}
getEvent(id: string): Observable<Event> {
// return a document as a type
this.document = this.collection.doc(id);
this.document$ = this.document.valueChanges();
return this.document$;
}
setId(id: string) {
this.id = id;
}
getId() {
return this.id;
}
}
homepage.component.ts
// Angular Imports
import { Component, OnInit } from "@angular/core";
// Internal Imports
import { AuthService } from "../../auth/auth.service";
import { NavbarComponent } from "../../components/navbar/navbar.component";
import { EventCardComponent } from "../../components/event-card/event-card.component";
import { Event } from "../../event/event";
import { EventsService } from "../../event/events.service";
// AngularFire imports
import { AngularFirestore } from "angularfire2/firestore";
// rxjs imports
import { Observable } from "rxjs";
// firebase
import * as firebase from "firebase";
@Component({
selector: "app-homepage",
templateUrl: "./homepage.component.html",
styleUrls: ["./homepage.component.css"]
})
export class HomepageComponent implements OnInit {
constructor(
private authService: AuthService,
private eventsService: EventsService,
private afs: AngularFirestore // public navbar: NavbarComponent
) {}
events: Event[] = [];
myEvents: Event[] = [];
eventsFilled: boolean;
getEvents(): void {
this.eventsService.getEvents().subscribe(events => {
this.events = events;
console.log("the length of the events pulled are: " + this.events.length);
});
}
ngOnInit() {
this.getEvents();
console.log(
"the length of the events logged from onInit are: " + this.events.length
);
}
}
最佳答案
您指的是组件中的局部变量吗?
如果是这样,当您离开某个组件时,该组件将被销毁。它在任何属性(局部变量)中的任何状态都消失了。您不能在路由之间的组件中保留状态。
相反,您可以将该状态存储在服务中。如果您使用根应用程序注入(inject)器注册服务,那么即使组件被销毁,该服务也会保留。
关于angular - 来回更改路线后可观察到的数据消失了,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51862952/
我正在尝试在项目中学习和添加 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
我是一名优秀的程序员,十分优秀!