3
私には分かりません。誰かが何かアドバイスを提供できたら、私はそれを感謝します。未処理プロミス拒否:nullのメソッド 'push'を呼び出すことはできません
私は、Meteor/MongoでIonic2を使用してチャットアプリケーションを構築しています。
私は、次のコードを持っている:
private findChats(): Promise<Mongo.Collection<Chat>> {
let promise: Promise<Mongo.Collection<Chat>> = new Promise<Mongo.Collection<Chat>>(resolve => {
let registeredIds: String[] = [this.senderId];
for (let i = 0; i < this.jobModelsForSender.length; i++) {
console.log('findChats: registeredIds.push this.jobModelsForSender[i].id: ' + registeredIds + ' - ' + this.jobModelsForSender[i].id);
registeredIds.push('J' + this.jobModelsForSender[i].id);
console.log('findChats: pushed: ' + registeredIds);
}
this.subscribe('chats', this.senderId, registeredIds,() => {
console.log('findChats: in subscribe: ' + this.senderId+' '+registeredIds);
let chats: Mongo.Cursor<Chat> = Chats.find(
{ memberIds: { $in: registeredIds } },
{
sort: { lastMessageCreatedAt: -1 },
transform: this.transformChat.bind(this),
fields: { memberIds: 1, lastMessageCreatedAt: 1 }
}
);
console.log('findChats: chats: ' + chats);
this.chats = chats;
let localChatCollection: Mongo.Collection<Chat> = new Mongo.Collection<Chat>(null);
chats.forEach((chat: Chat) => {
localChatCollection.insert(chat);
});
console.log('findChats: resolve(localChatCollection): ' + localChatCollection);
resolve(localChatCollection);
});
});
return promise;
}
をしかし、私は次のような出力が得られます。
findChats: registeredIds.push this.jobModelsForSender[i].id: P8 - 72 app.bundle.js:118232
findChats: pushed: P8,J72 app.bundle.js:118234
findChats: registeredIds.push this.jobModelsForSender[i].id: P8 - 72 app.bundle.js:118232
findChats: pushed: P8,J72 app.bundle.js:118234
findChats: registeredIds.push this.jobModelsForSender[i].id: P8 - 72 app.bundle.js:118232
findChats: pushed: P8,J72 app.bundle.js:118234
Unhandled Promise rejection: Cannot call method 'push' of null ; Zone: <root> ; Task: Promise.then ; Value: TypeError {stack: (...), message: "Cannot call method 'push' of null"} zone.js:461
Error {rejection: TypeError, promise: ZoneAwarePromise, zone: Zone, task: ZoneTask, stack: (...)…}
zone.js:463
Unhandled Promise rejection: Cannot call method 'push' of null ; Zone: <root> ; Task: Promise.then ; Value: TypeError {stack: (...), message: "Cannot call method 'push' of null"} zone.js:461
Error {rejection: TypeError, promise: ZoneAwarePromise, zone: Zone, task: ZoneTask, stack: (...)…}
zone.js:463
Unhandled Promise rejection: Cannot call method 'push' of null ; Zone: <root> ; Task: Promise.then ; Value: TypeError {stack: (...), message: "Cannot call method 'push' of null"} zone.js:461
Error {rejection: TypeError, promise: ZoneAwarePromise, zone: Zone, task: ZoneTask, stack: (...)…}
zone.js:463
findChats: in subscribe: P8 P8,J72 app.bundle.js:118243
findChats: chats: [object Object] app.bundle.js:118249
findChats: resolve(localChatCollection): [object Object]
あなたは私がzone.js
のエラーを取得しています、見ることができるように。私が見る限り、これをデバッグするとログが表示されると、push
はregisteredIds
に正常に反映されます。関数を終了し、promise
を返します。その後、エラーがログに記録されるzone.js
に入ります。
ここでの問題は、約束事が同期的ではなく非同期的に解決されるということです。つまり、実行時にコードのregisteredIdsにはまだ存在しません。約束が解決されるのを待ってから、コード実行を続行する必要があります。コンソールに出力するだけでなく、内部のブラウザデバッガで実際にデバッグして、未定義のタイミングを確認してください。 – Anton
アントンで見る方向をありがとう、私はそれをチェックします。 – Richard
ありがとう、それは、私は同じ約束を同時に呼んでいたイベントがあった。そのイベントへの引き金を取り除くとすぐに、私は何の誤りもありません。ヘルプをよろしくお願いいたします。 – Richard