0

我正在迈出第一步,如果 View 获取或来自外部Backbone.js的值,我在理解如何设置默认值方面遇到了一些问题:undefinednull

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();
});

是否存在一种简单的方法来做到这一点?

4

1 回答 1

1

您的意思是,如果 data.type 未定义,如何获取默认值?

您需要定义一个默认值,然后分配一个未定义的值。通过执行 data.type || data.type_default,自动返回未定义的那个。

var data = {
 type : undefined,
 default_type : "something",
 ...
}

messageModel.set({
 type: data.type || data.default_type,
 ...
});
于 2013-03-24T22:31:15.323 回答