ejs的视图模板引擎

一、版本升级
        Express从2.0升级到3.0,将ejs的用法忽略,改为用户自定义形式。
        引入ejs/index.js的模块,来支持ejs的模版引擎
二、引入引擎的模块,然后在app中调用engine函数改造ejs引擎
        app.engine('ejs', engine);
        将layout.ejs设置成默认的布局模版
        app.locals._layoutFile='layout'
三、如果项目分前后台,那么只有一个布局模版,怎么办?
        res.render('pcat',{_layoutFile:'pcatlayout'});//调用模版引擎的时候指定模版
四、片段视图
        Express的视图系统还支持片段视图,它就是一个页面的片段,通常是重复的内容,用于迭代显示,通过它你可以将相对独立的页面块分割出去,而且可以避免显示的使用for循环。
        partial是一个可以在视图中使用的函数,它接受两个参数,第一个是片段视图的名称,第二个可以是一个对象或一个数组,如果是一个对象,那么片段视图上下文变量引用的就是这个变量,如果是一个数组,那么其中每个元素一次被迭代应用到片段视图。片段视图中上下文变量名就是视图文件名。
        list.ejs   listitem.ejs
   五、视图助手。
            允许在视图中访问一个全局的函数或对象,不用每次调用视图解析的时候单独传入,
            视图助手分为两类,分别是静态视图助手和动态视图助手,这两者的差别在于,静态视图注助手可以是任何类型的对象,包括接受任意参数的函数,但访问到的对象必须是用户请求无关的。而动态视图助手只能是一个函数。这个函数不能接受任何参数,但是可以访问req和res两个对象。
        静态视图助手:                
            app.locals({
                inspect:function(obj){
                    return util.inspect(obj,true)+"    解析成功";
                }
            })
        动态视图助手:
            res.locals({
                headers:function(req,res){
                    return req.headers;
                }
            })
            
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值