异步查询JSON对象

时间:2016-07-16 06:08:15

标签: javascript json node.js

我一直在玩NPM中一个名为JSON-Query的模块,我最初能够在我的js中嵌入JSON来创建模块功能。

我花了大约两天时间尝试查询外部和JSON文件中的JSON。

正在运行的原始代码看起来像这样。

var jsonQuery = require('json-query')
var data = {
  people: [
    {name: 'Matt', country: 'NZ'},
    {name: 'Pete', country: 'AU'},
    {name: 'Mikey', country: 'NZ'}
  ]
}

jsonQuery('people[country=NZ].name', {
  data: data
}) //=> {value: 'Matt', parents: [...], key: 0} ... etc 

我能够查询内部JSON以找到我正在寻找的密钥。

我意识到我需要能够在代码生效时更新JSON,因此我将JSON移动到了自己的文件中。

目前我的主要JS文件看起来像这样。

var jsonQuery = require('json-query');
var fs = require('fs');

function querydb(netdomain){
fs.readFile('./querykeys.json', 'utf8', function (err, data) {
    if (err){console.log('error');} 
    var obj = JSON.parse(data);

    console.log(jsonQuery('servers[netshare=Dacie2015].netdomain', {
          obj: obj
        }));



});
}

querydb();

包含json的我的JSON文件如下所示。

{
          "servers": [
            {"netdomain": "google.com", "netshare": "password", "authip":"216.58.203.46"},
            {"netdomain": "localhost", "netshare": "localghost", "authip":"127.0.0.1"},
            {"netdomain": "facebook.com", "netshare": "timeline", "authip":"31.13.69.228"}
          ]
}

我遇到的问题是,当运行QueryDB()函数时,我无法再查询JSON,无论查询JSON的位置是什么,我都没有找到响应查找我的密钥。

当我尝试查询JSON文件时,我从服务器获得的响应是​​

{ value: null,
  key: 'netdomain',
  references: [],
  parents: [ { key: 'servers', value: null }, { key: null, value: null } ] }

非常清楚,我相信我的问题是我调用我的对象的方式,我使用了JSON-Query的结构,并且无法完成能够隔离密钥。

对此的任何帮助都是惊人的,我正在使用的模块可以在[NPM] https://www.npmjs.com/package/json-query

的npm找到

谢谢

1 个答案:

答案 0 :(得分:2)

我认为这只是一个错字。不应该这样:

obj: obj
是吗?

data: obj