2017-01-22 6 views
1

現在、MeteorとReactでnoughtsとcrossesゲームを構築しています。私が最初にアプリを起動すると、私は「Gamesのコレクションに新しい項目を作成し、小道具としてアプリケーションにこのオブジェクトのIDを送信します。createContainer()IDでオブジェクトを取得することができません

Meteor.startup(() => { 
    Meteor.call('games.create', function(error, result) { 
     var id = result; 
     render(<App gameId={id} />, document.getElementById('render-target')); 
    }); 
}); 

私は、取得するためにアプリケーションコンポーネントにcreateContainerを使用しますデータベース上のゲームなので、アプリケーション内で操作することができます。

export default createContainer(({gameId}) => { 
    Meteor.subscribe('games'); 
    console.log(gameId); 
    return { 
    gameState: Games.find(ObjectId(gameId)).fetch(), 
    }; 
}, App); 

このcreateContainerコードを追加した後、アプリケーションはレンダリングを停止しました。コンソールでは、非常に長いエラーメッセージが表示されます。前もって感謝します!

Exception in delivering result of invoking 'games.create': require<.imports.ui["App.jsx"]</exports.default<@http://localhost:3000/app/app.js?hash=d138fc2a4d2ee444a0b4b78d568bc9e3acf71f7c:758:5 
[email protected]://localhost:3000/packages/react-meteor-data.js?hash=913595fb1851d69206a4cd0ce5bfbacdc56a8830:282:16 
calculateData/this.computation</<@http://localhost:3000/packages/react-meteor-data.js?hash=913595fb1851d69206a4cd0ce5bfbacdc56a8830:164:22 
[email protected]://localhost:3000/packages/tracker.js?hash=9f8a0cec09c662aad5a5e224447b2d4e88d011ef:339:5 
[email protected]://localhost:3000/packages/tracker.js?hash=9f8a0cec09c662aad5a5e224447b2d4e88d011ef:229:5 
[email protected]://localhost:3000/packages/tracker.js?hash=9f8a0cec09c662aad5a5e224447b2d4e88d011ef:604:11 
calculateData/this.computation<@http://localhost:3000/packages/react-meteor-data.js?hash=913595fb1851d69206a4cd0ce5bfbacdc56a8830:156:16 
[email protected]://localhost:3000/packages/tracker.js?hash=9f8a0cec09c662aad5a5e224447b2d4e88d011ef:631:12 
[email protected]://localhost:3000/packages/react-meteor-data.js?hash=913595fb1851d69206a4cd0ce5bfbacdc56a8830:155:26 
[email protected]://localhost:3000/packages/react-meteor-data.js?hash=913595fb1851d69206a4cd0ce5bfbacdc56a8830:66:21 
require<.node_modules["react-dom"].lib["ReactCompositeComponent.js"]</ReactCompositeComponent.performInitialMount/<@http://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18931:18 
[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18658:12 
require<.node_modules["react-dom"].lib["ReactCompositeComponent.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18930:9 
require<.node_modules["react-dom"].lib["ReactCompositeComponent.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18841:16 
require<.node_modules["react-dom"].lib["ReactReconciler.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:11766:18 
require<.node_modules["react-dom"].lib["ReactCompositeComponent.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18954:18 
require<.node_modules["react-dom"].lib["ReactCompositeComponent.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:18841:16 
require<.node_modules["react-dom"].lib["ReactReconciler.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:11766:18 
[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:23920:16 
require<.node_modules["react-dom"].lib["Transaction.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:12730:13 
[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:23942:3 
require<.node_modules["react-dom"].lib["Transaction.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:12730:13 
require<.node_modules["react-dom"].lib["ReactDefaultBatchingStrategy.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:21609:14 
[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:11398:10 
require<.node_modules["react-dom"].lib["ReactMount.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:24136:5 
require<.node_modules["react-dom"].lib["ReactMount.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:24217:21 
require<.node_modules["react-dom"].lib["ReactMount.js"]</[email protected]://localhost:3000/packages/modules.js?hash=b2852da4b705e3b46ab5b20c9b94e15e453af050:24238:12 
require<.client["main.js"]</</<@http://localhost:3000/app/app.js?hash=d138fc2a4d2ee444a0b4b78d568bc9e3acf71f7c:395:3 
Meteor.bindEnvironment/<@http://localhost:3000/packages/meteor.js?hash=e3f53db3be730057fed1a5f709ecd5fc7cae1229:1105:17 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:3557:7 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:3577:5 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:4742:7 
Connection/[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:3385:7 
._launchConnection/self.socket.onmessage/<@http://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:2736:11 
[email protected]://localhost:3000/packages/underscore.js?hash=cde485f60699ff9aced3305f70189e39c665183c:149:7 
._launchConnection/[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:2735:9 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:175:9 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:1160:5 
[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:1218:13 
SockJS.websocket/[email protected]://localhost:3000/packages/ddp-client.js?hash=bc32a166cd269e06a394f9418e0024d805bab379:1365:9 

答えて

1

あなたの問題は、それを処理する方法を知らないObjectId()です。 次のようにします。

export default createContainer(({gameId}) => { 
Meteor.subscribe('games'); 
    console.log(gameId); 
    return { 
    gameState: Games.find(new Meteor.Collection.ObjectID(gameId)).fetch(), 
    }; 
}, App); 

理想的には、ハンドラとしてSubscriptionを使用する必要があります。

export default createContainer(({ gameId }) => { 
const gamesHandle = Meteor.subscribe('games'); 
const isLoadingGames = !gamesHandle.ready() 
const gamesState  = Games.find({ _id: gameId }).fetch() // <-- make sure 'Games' is imported or avilable globally 
return { 
    gamesState, 
    isLoadingGames 
}; 
}, App); 

次に、あなたがあなたの<App />コンポーネントでthis.props.isLoadingGamesにアクセスしてロードを表示するためにそれを使用することができます:)元this.props.isLoadingGames ? 'Loading...' : 'Finished...'

+0

残念ながら、これは動作しません。私はあなたのもの(2番目のもの)と私のcreateContainer関数を置き換えましたが、これは助けにはなりません。まだ取得中: 'games.create'を呼び出した結果の配信で例外が発生しました:MongoID.ObjectIDなど 関連性がある場合、私のAppコンポーネントはすべて、すべてのロジックを持つゲームコンポーネントをレンダリングします。 <ゲーム用ゲームステート= {this.props.gameState} isLoadingGames = {this.props.isLoadingGames} /> – LondonBoy

+0

あなたは理解するのがちょっと難しいですか?あなたの問題 –

+0

確かに、ID:157 588 160 – LondonBoy

関連する問題