如何最好地将JSON对象值与JScript中的固定数组进行比较

时间:2018-11-23 16:27:56

标签: arrays json loops for-loop jscript

我想将JSON值与值数组进行比较,但是我不知道最好的情况是什么。

我有一个带有期望值的JSON对象(可以有1个值,2个或更多值) 我有一个数据库函数,它返回固定数量的值,一直说10个值,我想知道我的JSON值是否匹配来自数据库的正确值。 例如:

我的JSON变量是:

    if ((rs.BOF) && (rs.EOF))
    {
        //nothing found;
    }
    else
    {
        while (!rs.EOF)
        {
            aDetails.push(
            {
                "id": rs.fields("id").Value,
                "name": rs.fields("name").Value,
                "age": rs.fields("age").Value,
                "sex": rs.fields("sex").Value,
                "hobby": rs.fields("hobby").Value
            });
            rs.MoveNext();
        }
    }
     rs.close;
 //Close connection then return
 return aDetails;

我的数据库会将一些值推送到对象数组。

例如:

{{1}}

基本上,我想确保来自JSON的值与来自数据库的正确值匹配。 (例如id)。

2 个答案:

答案 0 :(得分:4)

我假设aDetails的数据如下所示。

let aDetails = [{
  "id": "123",
   "name": "as",
   "age": 23,
   "sex": "m",
   "hobby": "abc"
}, {
  "id": "1234",
   "name": "as1",
   "age": 23,
   "sex": "m",
   "hobby": "abc"
}, {
  "id": "12",
   "name": "as2",
   "age": 23,
   "sex": "m",
   "hobby": "abc"
}]

var expValues = {
            "id": "123",
            "age": 23
        };
        
function isObjectMatched(obj) {
  return aDetails.some(d => Object.entries(obj).every(([k, v]) => d[k] == v))
}

console.log(isObjectMatched(expValues))

答案 1 :(得分:0)

这是为对象列表建立索引的通用方法,以便使用任何属性配置快速检索。

o_seq < v_cnt -N

这里是使用方法

// javascript version
function makeIndex (arrayOfObject, listOfPropertyToIndex) {
  var index = {};

  index.objToKey = function (o) {
    var key = [];
    listOfPropertyToIndex.forEach((p) => {
      key.push(""+o[p]);
    });
    return key.join("_");
  };

  arrayOfObject.forEach((o) => {
    index[objToKey(o)] = o;
  });

  index.match = function (object) {
    var key = index.objToKey(object);
    if (index.hasOwnProperty(key)) {
      return index[key];
    };
    return null;
  });

  return index;
}

// jscript version
function makeIndex (arrayOfObject, listOfPropertyToIndex) {
  var index = {};

  index.objToKey = function (o) {
    var key = [];
    for (var p in o) {
      if (o.hasOwnProperty(p)) {
        key.push(""+o[p]);
      }
    }
    return key.join("_");
  };

  for (var i = 0; i < arrayOfObject.length; ++i) {
    index[objToKey(arrayOfObject[i])] = o;
  } 

  index.match = function (object) {
    var key = index.objToKey(object);
    if (index.hasOwnProperty(key)) {
      return index[key];
    };
    return null;
  });

  return index;
}