2017-02-22 13 views
0

Я делаю небольшое веб-приложение узла с помощью Express. Но я получаю ошибки, если мои файлы ejs содержат инструкции else. Если это не ясно, вот MWE:.ejs файл не отображается, если содержит инструкции else

страниц/test.ejs:

<html> 
<head></head> 
<body> 
    <% var foo = "x"; %> 
    <% if (2==3) {foo = "y";} %> 
    <% else {foo = "z";} //If I delete this line, everything works %> 

    <%= foo %> 
</body> 
</html> 

index.js:

var express = require('express'); 
var app = express(); 
app.set('port', (process.env.PORT || 5000)); 
app.set('views', __dirname + '/pages'); 
app.set('view engine', 'ejs'); 
app.get('/test/', function(request, response) { 
    response.render("test"); 
}); 

Если я после этого попытаться посетить LOCALHOST: 5000/тест, я видеть только сообщение об ошибке:

SyntaxError: Unexpected token else in C:\path\to\my\files\pages\test.ejs while compiling ejs

If the above error is not helpful, you may want to try EJS-Lint: https://github.com/RyanZim/EJS-Lint at new Function() at Template.compile (C:\path\to\my\files\node_modules\ejs\lib\ejs.js:524:12) at Object.compile (C:\path\to\my\files\node_modules\ejs\lib\ejs.js:338:16) at handleCache (C:\path\to\my\files\node_modules\ejs\lib\ejs.js:181:18) at tryHandleCache (C:\path\to\my\files\node_modules\ejs\lib\ejs.js:203:14) at View.exports.renderFile [as engine] (C:\path\to\my\files\node_modules\ejs\lib\ejs.js:412:10) at View.render (C:\path\to\my\files\node_modules\express\lib\view.js:126:8) at tryRender (C:\path\to\my\files\node_modules\express\lib\application.js:639:10) at Function.render (C:\path\to\my\files\node_modules\express\lib\application.js:591:3) at ServerResponse.render (C:\path\to\my\files\node_modules\express\lib\response.js:960:7)

Но если удалить <% else {foo = "z"} %> линии, все работает отлично! Что дает?

ответ

1

Это должно работать для вас

<html> 
<head></head> 
<body> 
    <% var foo = "x"; %> 
    <% if (2==3) {foo = "y";} else {foo = "z";} %> 
    <%= foo %> 
</body> 
</html> 

или, если вам это нужно в отдельных строках

<html> 
<head></head> 
<body> 
    <% var foo = "x"; %> 
    <% if (2==3) {foo = "y";} else { %> 
    <% foo = "z";} %> 
    <%= foo %> 
</body> 
</html> 
0

Вы можете попробовать и скомпилировать шаблон из автономного сценария:

const ejs = require('ejs'); 

console.log(ejs.compile(` 
<html> 
    ... 
</html> 
`, { debug : true })); 

С набором debug option вы можете увидеть, что шаблон скомпилирован:

var __output = [], __append = __output.push.bind(__output); 
    with (locals || {}) { 
    ; __append("\n<html>\n<head></head>\n<body>\n ") 
    ; var foo = "x"; 
    ; __append("\n ") 
    ; if (2==3) {foo = "y";} 
    ; __append("\n ") 
    ; else {foo = "z";} 
    ; __append("\n\n ") 
    ; __append(escapeFn(foo)) 
    ; __append("\n</body>\n</html>\n") 
    } 
    return __output.join(""); 

Обратите внимание, как ; __append() вставляется между if и else линии, нарушая синтаксис if() { ... } else { ... }.

Для решения я отвечу на ответ, отправленный @ ponury-kostek.