如何制作一个(i = 0; i

时间:2012-10-31 17:17:39

标签: data-binding for-loop ember.js handlebars.js view-helpers

  

可能重复:
  Custom for-loop helper for EmberJS/HandlebarsJS

我将Handlebars用于网站,我有一个重要问题:

有时你给你的模板一个完整的数组,你只想显示第一个元素...... 你怎么用车把做到这一点?我找不到......

1 个答案:

答案 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>

就是这样。

我知道这不是最优的,所以无论谁知道如何改进它,请告诉我:)