- 主页 > 生活百科 > >
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: [] } ] });});
推荐阅读
-
【君子兰】君子兰有4个“喜好”,满足它,叶子油绿硬挺,开花更美
-
「幽默笑话段子集锦」你这样叫别人会误会的,幽默笑话:我是做日语翻译的
-
秦海璐|刘涛秦海璐街头拍戏,大口撸串没包袱,见被偷拍配合镜头被赞温柔
-
央视:美国加州所有学校2019-2020学年将不再开学
-
-
-
星座小艾米|喜事连连,收入翻番的四大生肖,7月运势大旺
-
新华网|通讯:“朝着同一个方向努力,最后一定能战胜病毒”——感染新冠病毒秘鲁女孩与“汉语桥”的故事
-
运势:恭喜!7月2号,财神降喜,运势注定红火的生肖,金库暴涨
-
帽子|把天蓝色穿出高级感,裹身裙搭配帽子,看着神秘又有休闲感
-
杨浦时报|国家网络安全宣传周上海地区特色活动在杨浦启动
-
短视频|三大“短视频”平台崛起!短视频创作者迎来机遇,未来谁会成为王者?
-
Daimoi生产力工具来了,三星Note20华丽释出!白色款相机镜头太抢眼
-
央视新闻客户端|服贸会:文化交流和文化贸易相互促进
-
-
内需|稳外贸、布新局、扩内需,东莞全力稳住经济基本盘
-
-
光明网|3岁孩子“开车”撞伤2名路人后,竟然还行驶十多米
-
时尚丽人风行|李现今年首部综艺开播!穿古装卖力宣传新片,44码“巨幕脚”火了
-
陆战编辑部|反舰导弹反而落后中俄?,为什么曾经称霸海洋的美国海军