node.js学习笔记13—express视图

1.片段视图(partial)

express的视图系统支持 片段视图(partials),它就是一个页面的片段,通常是重复的内容,用于迭代显示。

通常用partials,可以将相对独立的页面块分割出去,而且可以避免显示地使用for循环。

eg:

在app.js新增:

app.get('/list', function(req, res) {
     res.render('list', {
     title : "List",
     items:[ 1991, 'miao', 'express' , 'Node.js']
    });  
});

在views目录下新建list.ejs,内容是:

<ul><%- partial('listitem' , items) %></ul>

同时新建listitem.ejs,内容是:

<li><%= listitem %></li>

最后的在页面中看到的源代码是:

<ul>
    <li>1991</li>
    <li>miao</li>
    <li>express</li>
    <li>Node.js</li>
</ul>

partial是一个可以在视图中使用函数,它接受两个参数,

第一个是片段视图的名称;

第二个数据,数据的类型可以是一个对象或一个数组。如果是一个对象,那么片段视图中上下文变量引用的就是这个对象。

如果是一个数组,那么其中每个元素依次被迭代应用到片段视图,片段视图中上下文变量名就是视图文件名,例如上面的“listitem” 

 

2.视图助手

express提供一种叫做视图助手的工具,功能是允许在视图中访问一个全局的函数或对象,不用每次调用试图解析的时候单独传入。  

partial就是一个视图助手。

视图有两类,分别是静态视图助手和动态视图助手。两者区别是:

静态视图助手可以是任何类型的对象,包括接受任意参数的函数,但访问道的对象必须是与用户请求无关的;

而动态视图助手只能是一个函数,这个函数不能接受参数,但可以访问req和res对象。

 

3.总结

视图助手本质其实就是给所有视图注册了全局变量,因此无需每次在调用模板引擎时,传递数据对象。在网站开发是,使用session会话时,会发现其价值。  

  

posted on 2015-11-18 16:12 施小喵 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/shixiaomiao/p/4974873.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值