2014
09-23

node.js向ejs模板发送数据的两种方式

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有传值时,便会显示;没传值时,也不会报错了。




亲测可行
「真诚赞赏,手留余香」