私のオブジェクトは、
{
"Team-A": {
"captain": "A",
"homeGround": "some ground",
"winLoss": "12-4-0"
},
"Team-B": {
"captain": "B",
"homeGround": "some ground 2",
"winLoss": "4-4-4"
}
}
この情報を次のように表示する必要があります。
<h1>Team-A</h1>
<h2>some ground</h2>
<h3>12-4-0</h3>
<h1>Team-B</h1>
<h2>some ground2</h2>
<h3>4-4-4</h3>
Nodejs:
MongoClient.connect("mongodb://localhost:27017/MY_DB_TEST", function(err, db) {
if(!err) {
console.log("We are connected");
var collection = db.collection('football_teams');
var stream = collection.find().stream();
stream.on("data", function(item){
console.log(item);
res.render('index', {obj: item });
});
}
});
翡翠:
h1= obj.captain
h2= obj.homeGround
h3= obj.winLoss
私のコンソール出力は次のとおりです。
{ _id: 51064fa1e0d5d118b4b29aa0,
'Team-A': {
'captain": 'A',
'homeGround": 'some ground',
'winLoss': '12-4-0'
} }
title is not defined
at eval (eval at <anonymous> (C:\node_modules\jade\lib\jade.js:176:8))
at exports.compile (C:\node_modules\jade\lib\jade.js:181:12)
at Object.exports.render (C:\node_modules\jade\lib\jade.js:216:14)
at View.exports.renderFile [as engine] (C:\node_modules\jade\lib\jade.js:243:13)
at View.render (C:\node_modules\express\lib\view.js:75:8)
at Function.app.render (C:\node_modules\express\lib\application.js:503:10)
at ServerResponse.res.render (C:\node_modules\express\lib\response.js:721:7)
at CursorStream.exports.index (C:\Users\HFR&D\Desktop\nodemongoexpress\routes\index.js:18:8)
at CursorStream.EventEmitter.emit (events.js:96:17)
at CursorStream._onNextObject (C:\Users\HFR&D\Desktop\nodemongoexpress\node_modules\mongodb\lib\mongodb\cursorstream
オブジェクトをループして、値Team-A/Team-Bとそれぞれの詳細を取得する方法がわかりません。
nodejs
とを使用してこれを実現するにはどうすればよいですかjade
。
アップデート:
20のチームがあるとすると、私のコレクションは20のドキュメントで構成されます。私がやりたいのは、コレクションをループして、上記のように20のドキュメントに情報を表示することです。
私のdb構造は正しいですか?チームごとに異なるドキュメントを用意する必要がありますか?
はいの場合、ヒスイでレンダリングしているときにドキュメントのタイトル(team-A、team-B)を動的に取得するにはどうすればよいですか?