什么可能导致Nativescript angular2失败的承诺?

时间:2016-07-12 08:18:17

标签: http promise angular2-nativescript

我正在尝试从数据库中获取Http GET,我可以访问它并可以在Postman中重现GET结果。

我已经在angular2 {N}中创建了一个服务,我执行此GET但是出现错误:

JS: EXCEPTION: Error: Uncaught (in promise): Response with status: 200  for URL: null

JS: STACKTRACE:
JS: Error: Uncaught (in promise): Response with status: 200  for URL: null
JS:     at resolvePromise (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:496:32)
JS:     at resolvePromise (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:481:18)
JS:     at /data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:529:18
JS:     at ZoneDelegate.invokeTask (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:314:38)
JS:     at Object.NgZoneImpl.inner.inner.fork.onInvokeTask (/data/data/org.nativescript.ndemo/files/app/tns_modules/@angular/core/src/zone/ng_zone_impl.js:37:41)
JS:     at ZoneDelegate.invokeTask (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:313:43)
JS:     at Zone.runTask (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:214:48)
JS:     at drainMicroTaskQueue (/data/data/org.nativescript.ndemo/files/app/tns_modules/zone.js/dist/zone-node.js:432:36)
JS: Unhandled Promise rejection: Response with status: 200  for URL: null ; Zone: angular ; Task: Promise.then ; Value: Response with status: 200  for URL: null
JS: Error: Uncaught

 (in promise): Response with status: 200  for URL: null

我的服务:

import { Headers, Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
export function createNonJsonResponse(http: Http, fullUrl: string): Promise<string>{
    return http.get(fullUrl)
            .toPromise()
            .then(response => response.text())
            // .catch(this.handleError);
}

我已经记录了给出的URL和Http,它们都很好。 我不知道为什么会这样,谷歌无法帮助我找到任何解决方案。

2 个答案:

答案 0 :(得分:2)

似乎,至少在我看来,@ angular / core Http模块没有按预期工作。我切换到nativescript的Http服务(https://docs.nativescript.org/cookbook/http)并设法完成我所需要的而没有任何问题。

答案 1 :(得分:1)

你在某个地方注射服务吗?在导出上方添加@Injectable()。如果您更改了稍微编写服务的方式并查看是否收到相同的响应,该怎么办?

@Injectable()
export class createNonJsonResponse {

  fullUrl: string = 'http://httpbin.org/get';

  constructor(private http: Http) {}

  getNonJsonResponse() {
     return this.http.get(this.fullUrl)
        .toPromise()
        .then(response => response.text())
        .catch(this.handleErrors);
    }
}

然后将其导入您的组件

import {createNonJsonResponse} from "./yourservicename.service"

最后称之为

this.createNonJsonResponse.getNonJsonResponse().then(function (data) {
  alert("here");
  //console.log(data);
  //console.dump(data);
})

这对我有用,我能够发出警报。