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