我正试图找到一种让我的过滤器兼顾两种方式的方法。
以下是我在节点上的代码:
var env = nunjucks.configure(__dirname + '/../templates', {
express: app
});
env.addFilter('date', function(str){
return 'ok';
});
在浏览器方面:
var env = new nunjucks.Environment();
env.addFilter('date', function(str){
return 'ok';
});
我想将我的过滤器放在可以在这两种不同环境中使用的地方,但我找不到这样做的解决方案。
在客户端,我使用的是nunjucks-slim版本。我的模板是使用gulp预编译的。
感谢您的帮助!
答案 0 :(得分:2)
您可以将过滤器放在单独的文件/模块中,然后将env作为参数传递。
例如。
/**
* @param env The nunjucks environment
*/
function(env){
env.addFilter('fancy', function(input){
return 'fancy ' + input
});
env.addFilter(...);
return env;
}
然后,您可以使用UMD包装器(https://github.com/umdjs/umd)使其与浏览器和服务器兼容。完成的包装器可能看起来像这样:
// custom_filters.js
(function (root, factory) {
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define([], factory);
} else if (typeof exports === 'object') {
// Node. Does not work with strict CommonJS, but
// only CommonJS-like environments that support module.exports,
// like Node.
module.exports = factory();
} else {
// Browser globals (root is window)
root.custom_filters = factory();
}
}(this, function () {
// Return a value to define the module export.
return function(env){
env.addFilter('fancy', function(input){
return 'fancy ' + input
});
return env;
};
}));
然后像这样使用它:
节点:
var env = nunjucks.configure(__dirname + '/../templates', {
express: app
});
require('./path/to/custom_filters')(env);
浏览器(全局):
var env = new nunjucks.Environment();
window.custom_filters(env);
浏览器(AMD):
define(
['nunjucks', 'path/to/custom_filters'],
function(nunjucks, custom_filters){
var env = new nunjucks.Environment();
return custom_filters(env);
}
);