Come loop su MONGODB Array con Express e Monk per creare una pagina per ogni elemento?

StackOverflow https://stackoverflow.com//questions/25084422

  •  02-01-2020
  •  | 
  •  

Domanda

Sto costruendo un'app Web con Express, Nodejs e Monk.Sto cercando di creare una pagina per ogni elemento di un array nel mio database My MongoDB.

I dati sono già nella raccolta di Collezioni con il tasto Coll_List Come SO:

{ "_id" : ObjectId("53dbaefd3d85d57492506f1f"), "coll_list" : [     "data_pagename1", 
     "data_pagename2", "data_pagename3" ] }
.

Ho pensato che potrebbe essere possibile loop su tutti gli elementi in Coll_List con qualcosa come:

 router.get('/index', function(req, res) {
     var db = req.db;
     var collection = db.get('collections');
     collection.find( "coll_list" , function(e,docs) {
       for (elems in docs) {
         res.render(elems, {
           elems : docs
         });
       }
     });
 });
.

Qualsiasi suggerimento o aiuto / puntatori su come fare ciò sarebbe molto apprezzato.

È stato utile?

Soluzione

Usa req.params

router.get('/coll/:id',
  function(req,res){
     //access the id by req.params.id
     //req.params.id will essentially be the _id of the document
     //use it to obtain data from mongoDB and render the page using that data
     //From the front end you make the call to /coll/<ObjectId> like
     // /coll/53dbaefd3d85d57492506f1f and you get that id in req.params.id and use it to
     //render data specific to that _id. 

  });
.

Pertanto, utilizzando un singolo percorso, sarai in grado di creare una pagina per ogni elemento in coll_list

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top