[英]Ember handlebars helper return value
我试图创建一个帮助程序,使我可以将帮助程序链接在一起,例如:
{{ chain "striptags" "<p>asdf</p>" "truncate" 2 }}
但是,似乎没有在Ember中调用帮助程序后返回值,而是最后一个arg有一个渲染缓冲区,该缓冲区由ember帮助程序操纵。 有没有办法使用普通的余烬车把帮助器并返回值? 我的参考代码:
/**
* Allows some basic chaining of helpers.
* {{ chain "helper1" arg1 arg2 "helper2" arg2 }}
*/
Ember.Handlebars.helper('chain', function() {
var helperArgs = [];
var helper;
var that = this;
var options = arguments[arguments.length - 1];
$.each(arguments, function(i, arg) {
if(Ember.Handlebars.helpers[arg]){
if(helper){
helperArgs.push(options);
helperArgs = [helper.apply(that, helperArgs)];
}
helper = Ember.Handlebars.helpers[arg];
}else{
helperArgs.push(arg);
}
});
return helper.apply(that, helperArgs);
});
这样的工作:
Ember.Handlebars.helper('chain', function() {
var that = this,
helpers = [],
current = null,
options = arguments[arguments.length - 1];
for (var i = 0; i < arguments.length - 1; i++) {
var arg = arguments[i],
helperFn = Ember.Handlebars.helpers[arg];
if (helperFn) {
current = {
fn: helperFn,
args: []
};
helpers.push(current);
}
else if (current) {
current.args.push(arg);
}
else {
throw new Error("Unknown helper: " + arg);
}
}
var prevResult = null;
$.each(helpers, function (index, helper) {
var args = helper.args.concat(options),
before = options.data.buffer.buffer;
if (prevResult) {
args.unshift(prevResult);
}
helper.fn.apply(that, args);
var after = options.data.buffer.buffer;
prevResult = after.slice(before.length).replace(/<\/?script[^>]*>/g, "");
if (index < helpers.length - 1) {
options.data.buffer.buffer = before;
}
});
});
JSBin 。
问题是,车把帮手并没有真正返回值。 相反,它们直接写入通过options参数提供的缓冲区中。 在上面的示例中,我直接操作此缓冲区以提取一个助手的乘积并将其作为下一个助手的第一个参数插入(去除余烬元标记只是WTF-ery的一个优点)。
如您所见,它可以在这种简单的用例中工作,但可能会因涉及更多内容而中断。 把手帮手并非设计为用作功能。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.