Вынести переменную в виде HTML в EJS по

Я использую библиотеку форм для узла.в JS (формы), который будет отображать форму для меня на бэкэнде так:

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();

последняя строка var signup_var signup_form_as_html = signup_form.toHTML(); создает блок HTML, который выглядит так:

<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>

в основном просто длинная строка HTML. Затем я пытаюсь отобразить его с помощью EJS и выразить, используя следующий код:

res.render('signup.ejs', {
    session: loginStatus(req)
    , form: signup_form_as_html
});

но при рендеринге HTML - это просто строка, которую я разместил выше, а не фактический HTML (и, таким образом, форма, как я хочу). Есть ли способ сделать эту строку отображаемой как фактический HTML с помощью EJS? Или мне придется использовать что-то вроде нефрита?

3 ответов


С ejs вы можете иметь

<% code %> 

... это код, который оценивается, но не распечатывается.

<%= code %>

... который является кодом, который оценивается и распечатывается (экранируется).

<%- code %>

... который является кодом, который оценивается и распечатывается (не экранируется).

поскольку вы хотите напечатать переменную и не избежать ее, ваш код будет последним типом (с -<%). В вашем случае:

<%- my_form_content %>

Для больше, см. полная документация ejs


октябрь 2017 обновление

на новый ejs (v2, v2.5.7) развитие происходит здесь:https://github.com/mde/ejs Старый EJS по (версии v0.5.x, 0.8.5, v1.0.0) доступен здесь https://github.com/tj/ejs

теперь с ejs вы можете сделать даже больше. Вы можете использовать:

  • вырвалась наружу с <%= %> (функция escape настраивается)
  • Unescaped сырцовый выход с <%- %>
  • Newline-режим обрезки ('newline прихлебывая') с -%> заканчивая тегом
  • пробел-режим обрезки (slurp все пробелы) для потока управления с <%_ _%>
  • поток управления с <% %>

так, в вашем случае это будет <%- variable %> здесь variable что-то вроде

var variable = "text here <br> and some more text here";

надеюсь, это кому-то поможет.


у меня была та же проблема с рендерингом ввода textarea из редактора wysiwyg, сохраненного как html в моей базе данных. Браузер не будет отображать его, но отобразит html как текст. После нескольких часов поиска, я узнал

<%= data %> сбежал данных при

<%- data %>left data 'raw'(unescaped), и браузер теперь может отображать его.