node.js中向ejs模板发送数据有以下两种方法:
方法一、
示例代码:
res.render('viewName',{name1:'value1', name2:'value2',...});
语法:
res.render(view, [locals], callback);
说明:
view:为模板文件名
locals:为模板中所有变量的key-value的JSON数据
callback:为回调函数
弊端:此方法在给模板赋值时,必须一次性将模板里的所有变量都传值,否则会报错。
方法二、
示例代码:
1)
res.locals({title:'首页'});
res.locals({showMessage:'欢迎来到首页'});
res.render('index');
2)
res.locals.title = '首页';
res.locals.showMessage = '欢迎来到首页';
res.render('index');
此方法中的两种方式都可以。
优点:不用一次性给模板里的所有变量都传值,可以分步传值,类似于PHP与smarty模板结合的方式。虽然可以分步传值,但是在渲染模板(res.render)之前,也必须给所有变量都传值,否则也会报错。这是和PHP与smarty模板结合的最大不同之处。
补充说明,一个解决:
上面提到,在给模板传值时,必须要将模板里的所有变量都传值,否则会报错。经过则才的试验,发现在ejs模板文件里,可以利用判断来解决此问题,示例代码如下:
<% if (locals.title) { %>
<%= locals.title %>
<% } %>
当title有传值时,便会显示;没传值时,也不会报错了。
亲测可行。