前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >node.js向ejs模板发送数据的两种方式

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

作者头像
Marser
发布2018-06-25 16:47:04
2K0
发布2018-06-25 16:47:04
举报
文章被收录于专栏:智能合约智能合约

e.js中向ejs模板发送数据有以下两种方法:

方法一、

javascript res.render('viewName',{name1:'value1', name2:'value2',...});

语法:

javascript res.render(view, [locals], callback);

说明:

代码语言:txt
复制
    view:为模板文件名
代码语言:txt
复制
    locals:为模板中所有变量的key-value的JSON数据
代码语言:txt
复制
    callback:为回调函数

弊端:此方法在给模板赋值时,必须一次性将模板里的所有变量都传值,否则会报错。

方法二、

代码语言:txt
复制
    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有传值时,便会显示;没传值时,也不会报错了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:201409-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档