Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/15.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/angularjs/21.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 异步查询JSON对象_Javascript_Json_Node.js - Fatal编程技术网

Javascript 异步查询JSON对象

Javascript 异步查询JSON对象,javascript,json,node.js,Javascript,Json,Node.js,我一直在使用NPM中的一个名为JSON查询的模块,我最初能够在js中嵌入JSON来实现模块功能 我花了大约两天的时间试图让它查询JSON文件中的外部JSON 运行的原始代码看起来是这样的 var jsonQuery = require('json-query') var data = { people: [ {name: 'Matt', country: 'NZ'}, {name: 'Pete', country: 'AU'}, {name: 'Mikey', cou

我一直在使用NPM中的一个名为JSON查询的模块,我最初能够在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 
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,所以我将JSON移到了自己的文件中

目前,我的主JS文件如下所示

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 
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"}
          ]
}
我遇到的问题是,我无法再查询JSON了,当运行函数QueryDB()时,无论查询JSON的位置是什么,我都找不到找到我的密钥的响应

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

{ value: null,
  key: 'netdomain',
  references: [],
  parents: [ { key: 'servers', value: null }, { key: null, value: null } ] }
非常清楚地说,我认为我的问题在于调用对象的方式,我已经使用了JSON查询的结构,并且无法完成隔离密钥的任务

这方面的任何帮助都将是惊人的,我正在使用的模块可以在[npm]的npm上找到


谢谢

我想这只是一个打字错误。这不应该:

obj: obj
是这个吗

data: obj

这成功了!这行代码的作用是什么?我理解obj来自JSON的解析,is data:函数用什么来应答?
data
是数组中的键
{data:obj}
表示存在一个数组,其中
“data”
作为键,
obj
作为值。您正在调用的函数需要一个名为
“data”
的键,因此您需要使用它。