- 主页 > 生活百科 > >
Node/JavaScript中的模板引擎( 三 )
这里我们的 comments 为空 , 所以显示了 期待你们的留言 。

文章插图
#if是把 Handlebars 的内置帮助器 。如果if语句返回true , 则将渲染#if块内部的块 。如果返回false , undefined , null , "" , 0或[] , 则不会渲染该块 。
#if仅接受一个条件 , 并且不能使用 JS 比较语法(===) 。如果需要使用多个条件或其他语法 , 则可以在代码中创建一个变量 , 然后将其传递给模板 。另外 , 你可以定义自己的 helper , 我们将在上一节中进行操作 。
使用循环由于帖子可以包含多个评论 , 因此我们需要一个循环渲染它们 。首先 , 我们先添加一些数据:
app.get('/', function (req, res) { res.render('home', { post: { author: '小智', image: '/uploads/allimg/220422/1R64VU3-1.jpg', comments: [ '前端小智终身学习者', '前端小智持续分享者', '虽然没啥流量 , 但也希望你也能坚持分享下去 , 帮助更多的初学者 ' ] } });});现在 , 在我们的模板中 , 使用#each循环遍历它们:
<nav class="navbar navbar-dark bg-dark"> <a class="navbar-brand" href=https://www.isolves.com/it/cxkf/yy/js/2020-10-19/"#">Book Face
此文章由 {{post.author}} 发布
{{#if post.comments}}
{{#each post.comments}} - {{this}}
{{/each}}
{{else}}
{{/if}}
在#each循环中 , 可以使用this来引用当前迭代中的元素 。在我们的示例中 , 它引用了一个随后被渲染的字符串

文章插图
如果posts是一个对象数组 , 你也可以访问该对象的任何属性 。例如 , 如果有一个人员数组 , 你可以简单地使用this.name来访问name字段 。
现在 , 为我们的 posts 添加多个数据:
app.get('/', function (req, res) { res.render('home', { posts: [ { author: '小智', image: '/uploads/allimg/220422/1R64VU3-1.jpg', comments: [ '前端小智终身学习者', '前端小智持续分享者', '虽然没啥流量 , 但也希望你也能坚持分享下去 , 帮助更多的初学者 ' ] }, { author: '前端大智', image: '/uploads/allimg/220422/1R64VU3-1.jpg?2', comments: [] } ] });});
推荐阅读
-
宝蓝|“南孚组合”被拆散!宝蓝时隔242天再回赛场,DMO被IG三辅助轮换摇晕
-
5g网络|迪拜富豪初次体验中国5G网络,刚一上手就蒙圈了:这就是所谓的5G?
-
|泰达新援引进又赶了个晚集,凑数式引援难解球队当前困局
-
-
青年|大快人心!活了2年的Steam国产垃圾山寨游戏,终于被G胖ban了!
-
-
孔明说车|博越“嫁接版”皮卡到店!网友:自取其辱,吉利设计师真会偷懒
-
鲁班被称木匠鼻祖,为何《鲁班书》却成禁书?网友:堪称葵花宝典
-
证券时报网|创纪录!174亿“聪明资金”撤离,A股应声调整,行情到哪儿了?
-
-
新冠肺炎疫情|大连:停止餐饮服务经营单位聚集性就餐
-
-
|电影《林海雪原》,百鸡宴成八一厂工作餐,土匪黑话是什么意思
-
-
筑垒地域@负责人首次公开任务细节,火星,中国人来了!模拟测试进展顺利
-
#世上现存最年长熊猫迎38岁生日#世上现存最年长熊猫迎38岁生日 相当于人类110-140岁高龄
-
『』世界上最大的蜥蜴——科莫多巨蜥,体长可达3米(性格凶残)
-
观测|真·大彗星来了!未来一周,有可能用肉眼直接看到它
-
#数学#学生党利器!微软出品的这个小众APP,帮你搞定数学难题!
-
智通财经金泰丰国际控股(08479)一季度净亏损139.8万元,盈转亏