KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-handlebars

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-handlebars相关的知识,希望对你有一定的参考价值。

koahub-handlebars

koahub-handlebars

koahub handlebars templates

$ npm install koahub-handlebars
 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);
 

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(‘linkfunction(texturl{
  text hbs.Utils.escapeExpression(text);
  url  hbs.Utils.escapeExpression(url);
 
  var result ‘<a href="‘ + url ‘">‘ + text ‘</a>;
 
  return new hbs.SafeString(result);
});

Your helper is then accessible in all views by using, {{link "Google" "http://google.com"}}

The registerHelperUtils, 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;
});

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.

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.

<!DOCTYPE html>
<html>
<head>
  <title>{{title}}</title>
</head>
<body>
  {{{body}}}
</body>
</html>

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.

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‘)

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 [email protected];
  yield next;
});

The state object is a javascript Object. The properties added to it will be exposed as local variables within your views.

<title>{{title}}</title>
 
<p>Contact : {{email}}</p>

koa-hbs

  1. Configuration file incremental changes
  2. Modify some of the features and the default configuration
  3. ...

 

源码详情:http://js.koahub.com

技术分享

以上是关于KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-handlebars的主要内容,如果未能解决你的问题,请参考以下文章

KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-skip

KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-body-res

KoaHub.js -- 基于 Koa.js 平台的 Node.js web 快速开发框架之koahub-loader

基于 Koa平台Node.js开发的KoaHub.js连接打印机的代码

基于 Koa.js 平台的 Node.js web 快速开发框架KoaHub.js demo 可安装

KoaHub.js:使用ES6/7特性开发Node.js框架