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

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

    亲测可行。 
     
 
    

你可能感兴趣的:(PHP,smarty,node.js,ejs,expressjs)