繁体   English   中英

如何在 Angular2 应用程序中匹配双簧管节点事件中的每个新行分隔的 json 对象?

[英]How to match each new line delimited json object in oboe's node-event in Angular2 app?

我有返回这样的数据的API:

{"t":"point","id":817315,"tableid":141,"classid":142,"state":0,"loc":[6850735.34375,24501674.0039063]}
{"t":"line","id":817314,"tableid":204,"classid":2102,"loc":[[6850335.8828125,24501476.50390625],[6850341.48828125,24501476.8828125],[6850362.171875,24501492.21484375],[6850387.4140625,24501508.86328125],[6850442.66796875,24501545.69921875],[6850502.34375,24501584.0078125],[6850558.3359375,24501619.37109375],[6850611.375,24501654.73046875],[6850671.05078125,24501693.04296875],[6850708.62109375,24501687.1484375],[6850735.34375,24501674.00390625]]}

用这样的代码:

    oboe('http://localhost:19100/pn/api/v1/fetch?cgid=22&north=6853000.0&east=24505000&south=6850000.0&west=24500000.0')
    .node('*', (row) => {
        console.log(row);

        return oboe.drop;
    })
    .done(() => {

        return oboe.drop;
    })
    .fail((err) => {
        // error
        console.log('oboe fail ', err);
        return oboe.drop;
    });

我们不是针对每一行而是针对每个单独的值来进行节点回调。 即行的值是第 1 次“点”,第 2 次 817315,第 3 次 141 等等。

我的目标是在每一行都有一个 json 对象被读入一个对象。

我问了类似的问题,但因为第一个问题是 api 服务 CORS 问题,所以它变成了 CORS 问题,我据此重新命名。

此服务器响应是一种不好的做法。 由于您的 API 在 localhost 上运行,我相信您可以更改此响应。 请让您的 API 响应 JSON 数组。

[
{"t":"point","id":817315,"tableid":141,"classid":142,"state":0,"loc":[6850735.34375,24501674.0039063]},
{"t":"line","id":817314,"tableid":204,"classid":2102,"loc":[[6850335.8828125,24501476.50390625],[6850341.48828125,24501476.8828125],[6850362.171875,24501492.21484375],[6850387.4140625,24501508.86328125],[6850442.66796875,24501545.69921875],[6850502.34375,24501584.0078125],[6850558.3359375,24501619.37109375],[6850611.375,24501654.73046875],[6850671.05078125,24501693.04296875],[6850708.62109375,24501687.1484375],[6850735.34375,24501674.00390625]]}
]

这仅回答以下问题:如何将每个 json 对象与节点模式匹配?

代表 json 对象的每一行都与模式 '!' 匹配所以代码是这样的:

        oboe(url)
        .node('!', (row) => {
            console.log(row);
        })
        .on('end', () => {
            console.log('Stream finished');
        });

上面的代码在处理所有 json 对象时记录每个 json 对象和“流完成”。

现在修改了标题和问题以更好地匹配这个答案,我可能会问另一个更具体的问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM