答案 0 :(得分:0)
我是这样做的(它有效!!!)
首先, 我在我的模型中有一个'预览'属性/函数,它只返回一个数组中的arrayController:
objectToLoop = Ember.Object.extend({
...
arrayController: [],
preview: function() {
return this.get('arrayController').toArray();
}.property('arrayController.@each'),
...
});
然后,我添加了一个新的Handlebars助手:
Handlebars.registerHelper("for", function forLoop(arrayToLoop, options) {
var data = Ember.Handlebars.get(this, arrayToLoop, options.fn);
if (data.length == 0) {
return 'Chargement...';
}
filtered = data.slice(options.hash.start || 0, options.hash.end || data.length);
var ret = "";
for(var i=0; i< filtered.length; i++) {
ret = ret + options.fn(filtered[i]);
}
return ret;
});
感谢所有这些魔力,我可以在我的观点中称之为:
<script type="text/x-handlebars">
<ul>
{{#bind objectToLoop.preview}}
{{#for this end=4}}
<li>{{{someProperty}}}</li>
{{/for}}
{{/bind}}
</ul>
</script>
就是这样。
我知道这不是最优的,所以无论谁知道如何改进它,请告诉我:)