Javascript中的参数和对象文字

时间:2014-09-25 08:47:58

标签: javascript

我有一个函数,我传递一些值。我创建一个数组,并希望创建两个名称/值对。参数 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 

但这似乎不起作用。

1 个答案:

答案 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)); 

如果您的valueFielddisplayField属性不变,则可以使用工厂函数进一步干掉代码:

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