javascript - 在模板上渲染主干集合时无法获取模型的 cid

标签 javascript templates backbone.js mustache

我正在尝试在使用 mustache.js 构建的模板上渲染 Backbone 集合。问题是我无法在模板中获取模型的 cid。我的代码是

        <div class="phone span4">
            <h5> Phone Appointments</h5>
            {{ _.each(slots, function(slot) { }}
                {{ if(slot.aptType == "P"){ }}
                    <h6 cid="{{=slot.cid}}"  aptId="{{=slot.aptId}}"> {{=slot.beginTime}}  - {{=slot.endTime}} </h6>
                {{  }   }}
            {{  }); }}
        </div>

从上面的代码中,我可以得到 aptId、beginTime 和 end Time,但不能得到 Cid。如何在模板上渲染时从集合中获取模型的 Cid?

我在 View 中的渲染方法看起来像这样

    render:function(){
    var template = _.template($("#slot-display-template").html());
    compiledTmp = template({slots: this.collection.toJSON()})
    this.$el.append(compiledTmp);
    }

另外,使用 cid 作为模型的唯一标识符有什么缺点吗?

提前致谢!!!

最佳答案

默认情况下,cid 不包含在 toJSON 输出中。您需要在模型定义中覆盖 toJSON 并包含 cid

toJSON: function() {
  var json = Backbone.Model.prototype.toJSON.apply(this, arguments);
  json.cid = this.cid;
  return json;
}

关于javascript - 在模板上渲染主干集合时无法获取模型的 cid,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15298449/

相关文章:

c++ - VS2013模板类奇怪的行为

javascript - Jquery 或 Javascript mvc

backbone.js - 在 View 之间设置动画

javascript - 主干模型节省了客户端和服务器之间的更改循环

javascript - 在嵌入式 V8 引擎中调试 JavaScript

javascript - Fetch 返回空响应,但 Network 选项卡显示数据

c++ - C++ 模板的声明和定义分离

c++ - 模板可以决定 C++ 中参数的数量吗?

javascript - OpenUI5 加载 DateTimeInput 时出错

javascript - POST Javascript 生成的文件