我有一个函数,我传递一些值。我创建一个数组,并希望创建两个名称/值对。参数 valueField 和 displayField 是我传递的字符串。
在我实例化comboStore的底部,valueField和displayField被视为paramaters,这很好。但是,当我将对象推送到dataArray时,valueField和displayField不会被视为参数,而是视为文字值。
test:function (valueField, displayField, x, y) {
var dataArray = []
dataArray.push(
{
valueField: x, //this line does not use paramaters
displayField: y //this line does not use paramaters
}
)
var comboStore = {
fields: [valueField,displayField], //this line uses paramaters
data: dataArray
}
return comboStore;
},
如何对这样的对象文字进行参数化?
我试过了:
'' + valueField + '': x
但这似乎不起作用。
答案 0 :(得分:1)
使用subscript (or "bracket")表示法代替点表示法:
var data = {};
data[valueField] = x;
data[displayField] = y;
dataArray.push(data);
这有效,但它很冗长。您可以编写一个函数来封装对象创建逻辑:
function dataPoint(valueField, displayField, x, y) {
var data = {};
data[valueField] = x;
data[displayField] = y;
return data;
}
dataArray.push(dataPoint('a', 'b', 1, 2));
dataArray.push(dataPoint('c', 'd', 3, 4));
如果您的valueField
和displayField
属性不变,则可以使用工厂函数进一步干掉代码:
function dataPointFactory(valueField, displayField) {
return function(x, y) {
var data = {};
data[valueField] = x;
data[displayField] = y;
return data;
}
}
var makeDataPoint = dataPointFactory('valueField1', 'displayField1');
dataPoint.push(makeDataPoint(1, 2));
dataPoint.push(makeDataPoint(3, 4));