基于koa和nunjucks的服务端组件化渲染方案
- 基于koa和nunjucks
- 组件化开发
- 需要搭配构建工具shaun使用
npm install knc-render --save
// template render
const app = new Koa();
const KncRender = require('knc-render');
// new KncRender(koaContext, renderOptions, [comboOptions]);
const kncRender = new KncRender(app, {
ext: 'html', // 模板后缀名
path: '', // 模板路径
componentPath: '', // 组件路径
componentDefaultTmpl: 'index', // 组件默认模板名
staticURL: '/combo?', // 静态资源路径
staticCombo: true, // 静态资源是否开启combo
staticMap: {}, // 静态资源表
filter: {}, // nunjucks模板过滤器
dataFilter: function(data, extra) {}, // 数据过滤
nunjucksConfig: { // nunjucks配置
autoescape: true,
watch: true
}
}, {
dir: '', // 读取文件目录
ext: ['js', 'css'], // 允许读取文件的后缀名
maxAge: 60 * 60 * 1000 // 缓存时间,默认一天
});
kncRender.start();
关闭combo的时候,require进来的资源为staticURL目录下的文件
打开combo的时候,require进来的资源应该是dir目录下的,包含在ext里面的后缀名的文件
{% require "c_list/index.js" %}
component可以有4个参数,name,data,theme,extra
name
为组件名,data
为数据,theme
为主题名,extra
为额外参数,会直接做为dataFilter
的第二个参数
{% component name="c_list",data="" %}
这种情况会找componentPath目录下的c_list目录下的[componentDefaultTmpl.ext]文件,并且直接拿data来进行渲染
{
"css/header.css": "css/header-423dsdol.css",
"js/header.js": "js/header-gk34o1k3.js"
}
如果html文件里面包含<!-- [STYLE PLACEHOLDER] -->,则样式相关会插入这个位置,如果没有默认</head>之前;
如果html文件里面包含<!-- [SCRIPT PLACEHOLDER] -->,则脚本相关会插入这个位置,如果没有默认</body>之前
- c_header
|- images
|- scss
|- js
|- index.html
|- index.scss
|- index.js
|- schema.json