J'utilise la bibliothèque Forms pour Node.js ( Formulaires ), qui rendra un formulaire pour moi sur le backend comme suit :
var signup_form = forms.create({
username: fields.string({required: true})
, password: fields.password({required: true})
, confirm: fields.password({
required: true
, validators: [validators.matchField('password')]
})
, email: fields.email()
});
var signup_form_as_html = signup_form.toHTML();
La dernière ligne var signup_var signup_form_as_html = signup_form.toHTML();
crée un bloc de HTML qui se présente comme suit :
<div class="field required"><label for="id_username">Username</label><input type="text" name="username" id="id_username" /></div><div class="field required"><label for="id_password">Password</label><input type="password" name="password" id="id_password" /></div><div class="field required"><label for="id_confirm">Confirm</label><input type="password" name="confirm" id="id_confirm" /></div><div class="field"><label for="id_email">Email</label><input type="text" name="email" id="id_email" /></div>
Il s'agit en fait d'une longue chaîne de caractères HTML. J'essaie ensuite de la rendre en utilisant EJS et Express avec le code suivant :
res.render('signup.ejs', {
session: loginStatus(req)
, form: signup_form_as_html
});
Mais lors du rendu, le HTML est simplement la chaîne que j'ai affichée ci-dessus, plutôt que du vrai HTML (et donc un formulaire comme je le souhaite). Existe-t-il un moyen de faire en sorte que cette chaîne soit rendue comme du vrai HTML en utilisant EJS ? Ou dois-je utiliser quelque chose comme Jade ?