你不能直接这样做;对象文字中“:”的左侧必须是常量。你可以这样做:
window.MyModel = Backbone.Model.extend({
myDynamicVar : "country",
urlRoot: "api/myModel",
defaults: function(fieldName) {
var value = {
"id": null,
"country": {
"route":"test/test/test",
"class":".usa2",
"txt":"USA 2"
},
"region": "California",
"year": "",
"description": "",
"picture": ""
};
value[fieldName] = "USA";
return value;
}(this.myDynamicVar)
});
edit — 啊,我刚刚注意到“myDynamicVar”本身是外部对象的一部分。没有办法用this 以这种方式引用它,所以如果这是你想要做的,代码会有所不同:
window.MyModel = Backbone.Model.extend(function() {
var value = {
myDynamicVar : "country",
urlRoot: "api/myModel",
defaults: {
"id": null,
"country": {
"route":"test/test/test",
"class":".usa2",
"txt":"USA 2"
},
"region": "California",
"year": "",
"description": "",
"picture": ""
}
};
value.defaults.[value.myDynamicVar] = "USA";
return value;
}());
如果您希望myDynamicVar 本身 是动态的,那么您可以将其作为参数传入:
window.MyModel = Backbone.Model.extend(function(whichProperty) {
var value = {
myDynamicVar : "country",
urlRoot: "api/myModel",
defaults: {
"id": null,
"country": {
"route":"test/test/test",
"class":".usa2",
"txt":"USA 2"
},
"region": "California",
"year": "",
"description": "",
"picture": ""
}
};
value.defaults.[value[whichProperty]] = "USA";
return value;
}("myDynamicVar"));