Node.js EJS - Ne pas rendre le fichier si elle n'existe pas

voix
2

J'ai vue dossier structure et une profile_60113.ejs de fichier EJS comme celui-ci

views
    docs
        profile_60113.ejs

Je peux rendre dynamiquement le fichier comme celui-ci (où data.groupID == 60113):

<%- include(docs/profile_ + data.groupID); %>

Mais comment puis-je vérifier d'abord si le fichier existe? J'ai essayé ceci:

<% if (fs.existsSync(views/docs/profile_ + data.groupID)) { %>
    <%- include(docs/profile_ + data.groupID); %>
<% } %>

Ou ...

<% if (fs.existsSync(docs/profile_ + data.groupID)) { %>
    <%- include(docs/profile_ + data.groupID); %>
<% } %>

Mais n'a pas fonctionné ... const fs = require ( « fs ») est inclus dans le contrôleur et fs: fs est rendu

Créé 13/02/2020 à 23:54
source utilisateur
Dans d'autres langues...                            


1 réponses

voix
0

Ce qui fonctionne est par exemple:

Option 1 (Synchrone): Template

Du côté serveur:

const fs = require('fs');

var getGroupID = 60113;

res.render('docs', {
   page: setPage,
   data: {groupID: getGroupID},
   fs: fs   
});  

Modèle:

<% if (fs.existsSync("views/docs/profile_" + data.groupID + ".ejs")) { %>
    <%- include("docs/profile_" + data.groupID); %>
<% } %>

Option 2 (Synchrone): Serverside et modèle

Du côté serveur:

const fs = require('fs');

var getGroupID = 60113;

var getProfile;
if (fs.existsSync("views/docs/profile_" + getGroupID + ".ejs")) {
  getProfile = true;
} else {
  getProfile = false;
}

res.render('docs', {
   page: setPage,
   data: {groupID: getGroupID},
   profile: getProfile   
});       

Modèle:

<% if (profile) { %>
    <%- include("docs/profile_" + data.groupID); %>
<% } %> 

Option 3 (Asynchronous I / O): Serverside et modèle

Du côté serveur:

...

var getProfile;
try {
  await fs.promises.access("views/docs/profile_" + getGroupID + ".ejs");
  getProfile = true;
} catch (error) {
  console.log(error);
}   

...
Créé 14/02/2020 à 00:46
source utilisateur

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more