Вы не сможете сделать это напрямую; левая часть символа «:» в литерале объекта должна быть константой. Что вы можете сделать, это:
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)
});
изменить & mdash; ах, я только что заметил, что «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"));