- 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/
我使用 vanilla JS 通过 AJAX 向数据库发送请求。数据写入数据库没有问题。在刷新页面之前,我看不到被放入数据库中的内容。当我删除内容时也会发生同样的情况,我必须刷新才能看到内容消失了。
抱歉,这篇文章很长,我试图提供所有信息并解释我已经尝试过的内容。 问题: 我将经典的 Phoenix View 放入实时 View 中。虽然一切看起来都很好,但 echart 一完成绘制就消失了。好像
搜索了一下,没有找到我要找的东西。我有两个按钮,单击一次即可拉出两个不同的选择框,第二次单击它们就会消失。但是,我希望选择框 1 在单击按钮 2 时消失,反之亦然:选择框 2 将在单击按钮 1 时消失
我正在尝试使用自动布局使用“浮动”标题构建滚动视图。更确切地说,我正在尝试建立包含几列的日历视图。这些列中的每个列都应具有自己的标题,该标题应浮动在顶部,而该列可以垂直滚动到其下方。 如果一切正常,则
我正在尝试模仿星星背景。 星星是在加载时创建并随机散布在整个网站上的。到目前为止我已经调整了一些代码。 var star="•"; var numStars=100; for(var x=1;x•";
我查遍了整个网络,但找不到解决方案。我对 jQuery 也很陌生。 我的案例: 我有一个导航栏,其中的每个链接都会激活/触发一个megamenu(每个链接都有自己的megamenu)。 我需要什么:
我有一个可扩展的 ListView ,当我点击一行时,它会触发 onChildClick 或 onGroupClick,具体取决于我点击的是子项还是组。 如果我在 xml 布局文件中添加可点击的内容(
在我的程序中,我有一个 NSMutableData 变量,用于收集来自 http://www.nhara.org/scored_races-2013.htm 的信息。 .大约第三次从网站获取信息后,当
我一直在完美地使用 Genymotion,但是从最近几天开始我的 Genymotion 并打开它的 GPS 开始,我的 Genymotion 突然消失了。但是我的 eclipse 显示 Genymot
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
所以我的 Item::return_all() 有问题,因为我在 main.cpp 中调用它。早些时候我在 read_file() 和 for (auto data : example_item) 中
所有 UITableCells 在 UITableView 中滚动和触摸时消失。一切都以编程方式完成,我使用标准的 UITableViewCell 类。 我在某处读到包含我的单元格数据的数组可能被清空
我对 Swift 还很陌生。我的问题是我的 UICollectionView 正在消失。在 Xcode 中,它显示一切就绪,但当我在模拟器或设备上启动时,它消失了,只剩下导航栏和标签栏。 有谁知道是什
这是 this one的续题。较早的问题是在复选框上。但是后来我根据要求把check box改成了radio buttons。 现在我需要显示子单选按钮并在母单选按钮处于事件状态时更改背景颜色。一旦它
我用 JS 写了一个简单的脚本。当我将它放入 html 文档(在 body 标签的底部)时,它工作正常。当我尝试将它放入外部文档并链接它时,脚本运行但 canvas 元素消失(刚刚检查:当我将脚本放在
我正在尝试创建一个带有固定元素的滚动页面,当用户向下滚动页面时,该元素“始终”可见。例如,带有道路背景的汽车图像。因此,当用户向下滚动页面时,汽车看起来就像在路上行驶。虽然汽车出现在道路的顶部,但它必
这个问题在这里已经有了答案: How can I change CSS display none or block property using jQuery? (15 个答案) 关闭 4 年前。
我在市场上有一个支持小部件的应用程序。我对应用程序进行了一些重大更改,重新设计了很多内部结构,替换/重命名 Activity 等。其他更改包括从不同的共享首选项键获取小部件配置数据,尽管我已经编写了转
我有一个 fragment alertsfragment.java,它有一个 GridView 布局,当我打开它时,它工作正常,但是当我在其他选项卡之间滑动时,它就消失了。为了解释更多,我有一个 Ac
我是一名优秀的程序员,十分优秀!