2016-10-06 14 views
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のエラーを取得しています、見ることができるように。私が見る限り、これをデバッグするとログが表示されると、pushregisteredIdsに正常に反映されます。関数を終了し、promiseを返します。その後、エラーがログに記録されるzone.jsに入ります。

+0

ここでの問題は、約束事が同期的ではなく非同期的に解決されるということです。つまり、実行時にコードのregisteredIdsにはまだ存在しません。約束が解決されるのを待ってから、コード実行を続行する必要があります。コンソールに出力するだけでなく、内部のブラウザデバッガで実際にデバッグして、未定義のタイミングを確認してください。 – Anton

+0

アントンで見る方向をありがとう、私はそれをチェックします。 – Richard

+1

ありがとう、それは、私は同じ約束を同時に呼んでいたイベントがあった。そのイベントへの引き金を取り除くとすぐに、私は何の誤りもありません。ヘルプをよろしくお願いいたします。 – Richard

答えて

1

答えはおそらく多くの人には関係ありませんが、アントン氏は指摘したように、非同期にロードする約束事と関係がある問題です。

私は同じ約束を同時に呼んでいたイベントがありました。そのイベントへの引き金を取り除くとすぐに、私は何の誤りもありません。

関連する問題