Koa.js - Création de modèles

Pug est un moteur de création de modèles. Les moteurs de création de modèles sont utilisés pour supprimer l'encombrement du code de notre serveur avec du HTML, concaténant les chaînes de manière extravagante avec des modèles HTML existants. Pug est un moteur de création de modèles très puissant, doté de nombreuses fonctionnalités telles quefilters, includes, inheritance, interpolation, etc. Il y a beaucoup de chemin à parcourir à ce sujet.

Pour utiliser Pug avec Koa, nous devons l'installer à l'aide de la commande suivante.

$ npm install --save pug koa-pug

Une fois pug installé, définissez-le comme moteur de création de modèles pour votre application. Ajoutez le code suivant à votre fichier app.js.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

var _ = router(); //Instantiate the router

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

Maintenant, créez un nouveau répertoire appelé vues. Dans le répertoire, créez un fichier nommé first_view.pug et entrez les données suivantes.

doctype html
html
   head
      title = "Hello Pug"
   body
      p.greetings#people Hello Views!

Pour exécuter cette page, ajoutez l'itinéraire suivant à votre application.

_.get('/hello', getMessage); // Define routes

function *getMessage(){
   this.render('first_view');
};

Vous recevrez la sortie comme -

Ce que fait Pug, c'est qu'il convertit ce balisage très simple en html. Nous n'avons pas besoin de garder une trace de la fermeture de nos balises, pas besoin d'utiliser des mots-clés de classe et d'identifiant, utilisez plutôt "." et '#' pour les définir. Le code ci-dessus est d'abord converti en

<!DOCTYPE html>
<html>
   <head>
      <title>Hello Pug</title>
   </head>
    
   <body>
      <p class = "greetings" id = "people">Hello Views!</p>
   </body>
</html>

Pug est capable de faire bien plus que de simplifier le balisage HTML. Explorons certaines de ces fonctionnalités de Pug.

Balises simples

Les balises sont imbriquées en fonction de leur indentation. Comme dans l'exemple ci-dessus,<title> était en retrait dans le <head>tag, donc c'était à l'intérieur. Cependant, le<body> tag était sur la même indentation, donc c'était un frère de <head> marque.

Nous n'avons pas besoin de fermer les balises. Dès que Pug rencontre la balise suivante au même niveau ou au niveau d'indentation externe, il ferme la balise pour nous.

Il existe trois méthodes pour mettre du texte à l'intérieur d'une balise -

  • Espace séparé -
h1 Welcome to Pug
  • Texte diffusé -
div
   | To insert multiline text, 
   | You can use the pipe operator.
  • Bloc de texte -
div.
   But that gets tedious if you have a lot of text. 
   You can use "." at the end of tag to denote block of text. 
   To put tags inside this block, simply enter tag in a new line and 
   indent it accordingly.

commentaires

Pug utilise la même syntaxe que JavaScript (//) pour créer des commentaires. Ces commentaires sont convertis en commentaires html (<! - comment ->). Par exemple,

//This is a Pug comment

Ce commentaire est converti en -

<!--This is a Pug comment-->

Les attributs

Pour définir les attributs, nous utilisons une liste d'attributs séparés par des virgules, entre parenthèses. Les attributs de classe et d'ID ont des représentations spéciales. La ligne de code suivante couvre la définition des attributs, des classes et de l'ID pour une balise html donnée.

div.container.column.main#division(width = "100",height = "100")

Cette ligne de code est convertie en -

<div class = "container column main" id = "division" width = "100" height = "100"></div>

Passer des valeurs aux modèles

Lorsque nous rendons un modèle Pug, nous pouvons en fait lui transmettre une valeur de notre gestionnaire de route, que nous pouvons ensuite utiliser dans notre modèle. Créez un nouveau gestionnaire d'itinéraire avec le code suivant.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app // equals to pug.use(app) and app.use(pug.middleware)
});

var _ = router(); //Instantiate the router

_.get('//dynamic_view', dynamicMessage); // Define routes

function *dynamicMessage(){
   this.render('dynamic', {
      name: "TutorialsPoint", 
      url:"https://www.tutorialspoint.com"
   });
};

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

Ensuite, créez un nouveau fichier de vue dans le répertoire de vues, nommé dynamic.pug, à l'aide du code suivant.

html
   head
      title = name
   body
      h1 = name
      a(href = url) URL

Ouvert localhost:3000/dynamicdans votre navigateur et les suivants devraient être la sortie. -

Nous pouvons également utiliser ces variables passées dans le texte. Pour insérer des variables passées entre le texte d'une balise, nous utilisons la syntaxe # {variableName}. Par exemple, dans l'exemple ci-dessus, si nous voulons insérer des salutations à partir de TutorialsPoint, nous devons utiliser le code suivant.

html
   head
      title = name
   body
      h1 Greetings from #{name}
      a(href = url) URL

Cette méthode d'utilisation des valeurs est appelée interpolation.

Conditionnels

Nous pouvons également utiliser des instructions conditionnelles et des constructions en boucle. Considérez cet exemple pratique, si un utilisateur est connecté, nous voudrions afficher "Salut, Utilisateur" et sinon, nous voudrions lui montrer un lien "Connexion / Inscription". Pour y parvenir, nous pouvons définir un modèle simple tel que -

html
   head
      title Simple template
   body
      if(user)
         h1 Hi, #{user.name}
      else
         a(href = "/sign_up") Sign Up

Lorsque nous rendons cela en utilisant nos routes, et si nous passons un objet comme -

this.render('/dynamic',{user: 
   {name: "Ayush", age: "20"}
});

Il donnera un message affichant Salut, Ayush. Cependant, si nous ne transmettons aucun objet ou n'en transmettons aucun sans clé utilisateur, nous obtiendrons un lien d'inscription.

Inclure et composants

Pug fournit un moyen très intuitif de créer des composants pour une page Web. Par exemple, si vous voyez un site Web d'actualités, l'en-tête avec le logo et les catégories est toujours fixe. Au lieu de copier cela dans chaque vue, nous pouvons utiliser un include. L'exemple suivant montre comment nous pouvons utiliser un include -

Créez trois vues avec le code suivant -

header.pug

div.header.
   I'm the header for this website.

content.pug

html
   head
      title Simple template
   body
      include ./header.pug
      h3 I'm the main content
      include ./footer.pug

footer.pug

div.footer.
   I'm the footer for this website.

Créez un itinéraire pour cela comme suit.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

var _ = router(); //Instantiate the router

_.get('/components', getComponents);

function *getComponents(){
   this.render('content.pug');
}

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

Aller à localhost:3000/components, vous devriez obtenir la sortie suivante.

include peut également être utilisé pour inclure du texte brut, CSS et JavaScript.

Il existe de nombreuses autres fonctionnalités de Pug. Cependant, ceux-ci sont hors de portée de ce didacticiel. Vous pouvez explorer davantage Pug à Pug .