首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在handlebars.js模板中使用getters?

如何在handlebars.js模板中使用getters?
EN

Stack Overflow用户
提问于 2012-03-02 22:49:21
回答 3查看 1.2K关注 0票数 4

我正在尝试让我的handlebars.js模板做这样的事情:

代码语言:javascript
复制
<li>{{ user.get('firstName') }} {{ user.get('lastName') }}</li>   

显然,这是行不通的。handlebars.js是否有任何语法允许像上面那样直接使用getters?

谢谢。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-03-02 23:00:37

<li>{{user.firstName}} {{user.lastName}}</li>

尽管如果它在一个循环中(假设来自<li>),那么它应该是{{this.firstname}}

票数 0
EN

Stack Overflow用户

发布于 2014-11-27 08:41:21

这是在handlebars中工作,基本上是一个帮助器,然后使用{{get book "title"}}:

代码语言:javascript
复制
Handlebars.registerHelper('get', function(model, attributeName) 
{
    return model.get(attributeName); 
});

var templateStr = '<div class="book-title">{{get preferredBook "title"}}</div>'; 

var Book = Backbone.Model.extend({});
var b = new Book({title: 'Lord of the rings'});
var context = {
    preferredBook: b
}; 

var template = Handlebars.compile(templateStr);

var output = template(context);
expect(output).toBe('<div class="book-title">Lord of the rings</div>');
票数 0
EN

Stack Overflow用户

发布于 2015-02-03 06:17:59

更好,但时间是定制handlebars编译器的时间。以下代码需要添加到使用来编译模板的脚本中,而不是在运行时。将此代码添加到您的编译代码中,而不是运行时-这不是帮助器)。然后,您只需编写{{model.title}},该表达式将由编译器自动转换为标题(‘model.get’)。当然,如果‘Backbone.Model’不是模型,那么它将照常访问json属性。

代码语言:javascript
复制
Handlebars.JavaScriptCompiler.prototype.nameLookup = function(parent, name)
{
    var result = '((typeof(Backbone)!="undefined" && ' + parent + ' instanceof Backbone.Model) ? ' + parent + '.get("' + name + '") : ' + parent;
    if (/^[0-9]+$/.test(name))
    {
        return result + '[' + name + '])';
    }
    else if (Handlebars.JavaScriptCompiler.isValidJavaScriptVariableName(name))
    {
        return result + '.' + name + ')';
    }
    else
    {
        return result + '[\'' + name + '\'])';
    }
};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9535218

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档