0

我有一个 ionic 2 应用程序,我一直在使用本地数据进行测试。现在,我正在尝试向我的 api 发出一些 Ajax 请求以获取数据。

在我的app.js文件中,我正在定义我的组件,如下所示:

import {UserProvider} from './providers/user-provider';
...
    @App({
      templateUrl: 'build/app.html',
      providers: [UserProvider]
    })

然后,我的user-provider.js文件定义如下:

import {Injectable} from 'angular2/core';
import {Http, httpInjectables} from 'angular2/http';

@Injectable()
export class UserProvider {
    constructor(http: Http) {
        http.get('www.someURL.com').toRx().map(res => res.json())
            .subscribe(data => console.log(data));
    }
}

然后,最后,我用我的文件初始化我的“注册”视图signup.js

import {Page, NavController} from 'ionic/ionic';
import {TabsPage} from '../tabs/tabs';
import {UserProvider} from '../../providers/user-provider';

@Page({
  templateUrl: 'build/pages/signup/signup.html'
})
export class SignupPage {
  constructor(nav: NavController, userProvider: UserProvider) {
    this.userProvider = userProvider;
    this.nav = nav;
  }
}

我的预期结果是在我的注册视图初始化时,UserProvider将被注入。因此,它的构造函数将运行,这将触发' 构造http.get函数中的函数。UserProvider然后我应该在我的浏览器网络选项卡中看到一个网络调用。

但是,我收到此错误:

EXCEPTION: Error during instantiation of UserProvider! (SignupPage -> UserProvider)

app.bundle.js:33693 TypeError: http.get(...).toRx is not a function
    at new UserProvider (app.bundle.js:60706)

为什么会http.get.toRx()导致错误?我最初用这样的承诺尝试过这个:

http.get('www.someURL.com').then(() => {
            console.log('test');
        });

但这会引发类似的错误。

4

1 回答 1

2

在 angular2-beta0 中http.get()已经返回了一个Observable,你不需要调用它之前的.toRx()方法,你可以直接调用.map()等等。

于 2016-01-04T02:40:52.040 回答