我正在迈出第一步,如果 View 获取或来自外部Backbone.js
的值,我在理解如何设置默认值方面遇到了一些问题:undefined
null
var Status = {
Models: {},
Collections: {},
Views: {},
Templates:{}
}
Status.Models.Message = Backbone.Model.extend({
defaults:{
icon:'path/info-icon.png',
type:'warning',
title:'Information',
message:'There is nothing to read here.'
},
initialize:function () {
console.log("Status.Models.Message initialized");
}
});
Status.Views.Message = Backbone.View.extend({
initialize:function () {
console.log("Status.Views.Message initialized");
},
render:function () {
var template = _.template($('#status-message-template').html());
$('body').append($(this.el).attr('id', 'status-message').html(template(this.model.toJSON())));
var timer = setTimeout(function () {$('#status-message').addClass('enter')}, 1500);
}
});
我想找到一种方法让Backbone.js
覆盖 data
参数并强制它defaults
在它们是的情况下使用值""
,undefined
或者null
。
$(function(){
var data = {
type:undefined,
message:'This is the new message!'
};
var messageModel = new Status.Models.Message ();
messageModel.set({
type: data.type, // how to let it get defaults.type because data.type is undefined?
message: data.message
});
var messageView = new Status.Views.Message({
model:messageModel
});
messageView.render();
});
是否存在一种简单的方法来做到这一点?