• 技术文章 >php教程 >php手册

    基于 Koa平台Node.js开发的KoaHub.js的模板引擎代码

    2016-09-30 09:22:56原创725
    基于 Koa平台Node.js开发的KoaHub.js的模板引擎代码
    koahub-handlebars

    koahub-handlebars

    koahub handlebars templates

    Installation

    $ npm install koahub-handlebars
    Use with koa

    var koa = require('koa');
    var hbs = require('koahub-handlebars');

    var app = koa();

    // koahub-handlebars is middleware. `use` it before you want to render a view
    app.use(hbs.middleware({
    viewPath: __dirname + '/views'
    }));

    // Render is attached to the koa context. Call `this.render` in your middleware
    // to attach rendered html to the koa response body.
    app.use(function *() {
    yield this.render('index', {title: 'koahub-handlebars'});
    })

    app.listen(3000);

    Registering Helpers

    Helpers are registered using the #registerHelper method. Here is an example using the default instance (helper stolen from official Handlebars docs:

    hbs = require('koahub-handlebars');

    hbs.registerHelper('link', function(text, url) {
    text = hbs.Utils.escapeExpression(text);
    url = hbs.Utils.escapeExpression(url);

    var result = '' + text + '';

    return new hbs.SafeString(result);
    });
    Your helper is then accessible in all views by using, {{link "Google" "http://google.com"}}

    The registerHelper, Utils, and SafeString methods all proxy to an internal Handlebars instance. If passing an alternative instance of Handlebars to the middleware configurator, make sure to do so before registering helpers via the koahub-handlebars proxy of the above functions, or just register your helpers directly via your Handlebars instance.

    You can also access the current Koa context in your helper. If you want to have a helper that outputs the current URL, you could write a helper like the following and call it in any template as {{requestURL}}.

    hbs.registerHelper('requestURL', function() {
    var url = hbs.templateOptions.data.koa.request.url;
    return url;
    });
    Registering Partials

    The simple way to register partials is to stick them all in a directory, and pass the partialsPath option when generating the middleware. Say your views are in ./views, and your partials are in ./views/partials. Configuring the middleware via

    app.use(hbs.middleware({
    viewPath: __dirname + '/views',
    partialsPath: __dirname + '/views/partials'
    }));
    will cause them to be automatically registered. Alternatively, you may register partials one at a time by calling hbs.registerPartial which proxies to the cached handlebars #registerPartial method.

    Layouts

    Passing defaultLayout with the a layout name will cause all templates to be inserted into the {{{body}}} expression of the layout. This might look like the following.




    {{title}}


    {{{body}}}


    In addition to, or alternatively, you may specify a layout to render a template into. Simply specify {{!< layoutName }} somewhere in your template. koahub-handlebars will load your layout from layoutsPath if defined, or from viewPath otherwise.

    At this time, only a single content block ({{{body}}}) is supported.

    Options

    The plan for koahub-handlebars is to offer identical functionality as koa-hbs (eventaully). These options are supported now.

    viewPath: [required] Full path from which to load templates (Array|String)
    handlebars: Pass your own instance of handlebars
    templateOptions: Hash of handlebars options to pass to template()
    extname: Alter the default template extension (default: '.html')
    partialsPath: Full path to partials directory (Array|String)
    defaultLayout: Name of the default layout
    layoutsPath: Full path to layouts directory (String)
    disableCache: Disable template caching (default: '.true')
    Locals

    Application local variables ([this.state](https://github.com/koajs/koa/blob/master/docs/api/context.md#ctxstate)) are provided to all templates rendered within the application.

    app.use(function *(next) {
    this.state.title = 'My App';
    this.state.email = 'me@myapp.com';
    yield next;
    });
    The state object is a JavaScript Object. The properties added to it will be exposed as local variables within your views.

    {{title}}

    Contact : {{email}}


    Thanks

    koa-hbs

    Differents

    Configuration file incremental changes
    Modify some of the features and the default configuration
    ...
    官网:http://js.koahub.com

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:Thinkphp 生成订单号小案例 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • Yii2如何批量添加数据,Yii2批量添加数据• 用Xdebug修正PHP应用程序中的错误• PHP下打开phpMyAdmin出现403错误的问题解决方法• 第十三节--对象串行化• php实现refresh刷新页面批量导入数据的方法
    1/1

    PHP中文网