Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/beliefgp/koa-nunjucks-next
koa2 view render based on nunjucks
https://github.com/beliefgp/koa-nunjucks-next
Last synced: 3 months ago
JSON representation
koa2 view render based on nunjucks
- Host: GitHub
- URL: https://github.com/beliefgp/koa-nunjucks-next
- Owner: beliefgp
- Created: 2016-08-30T06:49:51.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-07-19T11:05:52.000Z (over 7 years ago)
- Last Synced: 2024-10-05T02:15:52.150Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 5.86 KB
- Stars: 11
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-koa - koa-nunjucks-next - [Nunjucks](http://mozilla.github.io/nunjucks/)视图渲染中间件, 支持异步过滤器,渲染原始字符串。 ![](https://img.shields.io/github/stars/beliefgp/koa-nunjucks-next.svg?style=social&label=Star) ![](https://img.shields.io/npm/dm/koa-nunjucks-next.svg?style=flat-square) (仓库 / 中间件)
README
# koa-nunjucks-next
[koa2](https://github.com/koajs/koa) view render based on [nunjucks](http://mozilla.github.io/nunjucks), support asynchronous filters.
## Installation
```
npm install koa-nunjucks-next
```## Warn
Do not use babel compile。
## API
#### `views(root, opts)`
* `root`: (default `views`) Views location. All views you `render()` are relative to this path.
* `opts` [nunjucks configure opts](http://mozilla.github.io/nunjucks/api.html#configure)
* `opts.globals`: nunjucks global values that will be available to all templates
* `opts.filters`: nunjucks filters, support asynchronous filter
* `opts.extensions`: nunjucks extensions (e.g. [highlight code blocks](https://github.com/ryanwild/nunjucks-highlight.js))```js
filters: {
asyncAdd1: (val1, val2) => {
return new Promise((resolve, reject) => {
setTimeout(() => resolve(val1 + val2), 2000);
});
},
asyncAdd2: async (val1, val2) => {
let val3 = await new Promise((resolve, reject) => {
setTimeout(() => resolve(100), 1000);
});return await new Promise((resolve, reject) => {
setTimeout(() => resolve(val1 + val2 + val3), 2000);
});
},
syncAdd: (val1, val2) => {
return val1 + val2;
}
}
```* `opts.extname`: (default `html`) Extension for your views
```js
// instead of this
await ctx.render('test.html')
// you can
await ctx.render('test')
```#### `ctx.render(template, content, [isStringTemplate])`
```js
// renders a template
await ctx.render('test', {})// renders a raw string
await ctx.render('{{ val1 | asyncAdd1(1) }}', { val1: 66666 }, true)```
## Example
```js
let views = require('koa-nunjucks-next');app.use(views('../views', {
filters: {
asyncAdd: (val1, val2) => {
return new Promise((resolve, reject) => {
setTimeout(() => resolve(val1 + val2), 2000);
});
},
syncAdd: (val1, val2) => {
return val1 + val2;
}
}
}));router.get('/test-template', async (ctx, next) => {
await ctx.render('test', {
'val1': 66666
});
});router.get('/test-string', async (ctx, next) => {
await ctx.render('{{ val1 | asyncAdd(1) }}', {
'val1': 66666
}, true);
}); //==> 66667```