没有Http的提供者。区域角度。任务承诺然后价值

时间:2018-01-20 12:15:06

标签: angular angular4-httpclient

我正在尝试从我的Angular2类调用Web API。

service.ts:

import { Component, OnInit, Injectable } from '@angular/core';
import { Http, RequestOptions, Headers  } from "@angular/http";
import { apimodel } from '../../_model/APImodel';
import Global = require('../../_utilities/constants/constants');
import { UserModel } from '../../_model/usermodel';
import 'rxjs/add/operator/toPromise';

@Injectable()
export class services
{
    constructor(private http: Http){ }

    getLogin(model : UserModel)  {
        let headers = new Headers({ 'Content-Type': 'application/json; charset=utf-8' });
        let options = new RequestOptions({ headers: headers });
        return this.http.post(Global.BASE_URL + '/login', model, options)
                .toPromise().then(res=><apimodel>res.json()).catch(this.handleError);
    }

    private handleError(error:any) {
        // In a real world app, we might use a remote logging infrastructure
        // We'd also dig deeper into the error to get a better message
        let errMsg = (error.message) ? error.message :
            error.status ? `${error.status} - ${error.statusText}` : 'Server error';
        console.log("Error");
        console.error(error); // log to console instead
        return Promise.reject(errMsg);
    }
}

login.ts:

import { Component, OnInit } from '@angular/core';
import { UserModel } from '../../_model/usermodel';
import { FormGroup, FormControl, Validators } from '@angular/forms';
import { ActivatedRoute, Router } from '@angular/router';
import Global = require('../../_utilities/constants/constants');
import {apimodel} from "../../_model/APImodel";
import { services } from '../../_utilities/services/services';


@Component({
    templateUrl: './_componant/login/login.html'
})

export class LoginComponent implements OnInit{
    model : UserModel = {id : 0, email : "", password : "", username : ""};
    myform : FormGroup;
    submitted : boolean = false;
    returnUrl : string;
    response : apimodel;

    constructor( private route: ActivatedRoute, private router: Router, private services : services){

    }
    ngOnInit(): void {
        this.myform = new FormGroup({
            username : new FormControl("", Validators.required),
            password : new FormControl("", Validators.required)
        })

        this.returnUrl = this.route.snapshot.queryParams['returnUrl'] || '/';
    }

    login(model : UserModel){
        this.submitted = true;
        if(this.myform.valid)
        {
            this.services.getLogin(model).then(result => console.log(result)).catch(error => console.log(error));
            //Call Web Service to login
            console.log(this.returnUrl);
            this.router.navigate([this.returnUrl]);
        }
    };
}

Module.ts:

import { NgModule, PipeTransform }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { ReactiveFormsModule  } from '@angular/forms';
import { AppComponent } from './_componant/app/app.component';
import { appRouterModule } from './app.route';
import { LoginComponent } from './_componant/login/login';
import { RegistrationComponent } from './_componant/registration/registration';
import { services } from './_utilities/services/services';



@NgModule({
  imports: [BrowserModule, ReactiveFormsModule ,appRouterModule],
  declarations: [AppComponent, LoginComponent, RegistrationComponent],
  bootstrap:    [AppComponent],
  providers: [services]
})

export class AppModule { }

如您所见,我已正确注入服务类,并在service.ts中正确添加Http

我在控制台中遇到以下错误:
enter image description here

2 个答案:

答案 0 :(得分:2)

你没有在你的module.ts文件中包含HttpModule。

import { NgModule, PipeTransform }      from '@angular/core';
import { HttpModule  } from '@angular/http';
import { BrowserModule } from '@angular/platform-browser';
import { ReactiveFormsModule  } from '@angular/forms';
import { AppComponent } from './_componant/app/app.component';
import { appRouterModule } from './app.route';
import { LoginComponent } from './_componant/login/login';
import { RegistrationComponent } from './_componant/registration/registration';
import { services } from './_utilities/services/services';

@NgModule({
  imports: [BrowserModule, ReactiveFormsModule, HttpModule, appRouterModule],
  declarations: [AppComponent, LoginComponent, RegistrationComponent],
  bootstrap:    [AppComponent],
  providers: [services]
})

export class AppModule { }
  

你错过了

     

从'@ angular / http'导入{HttpModule};

     

     

导入:[BrowserModule,ReactiveFormsModule, HttpModule ,appRouterModule],

答案 1 :(得分:1)

您需要在app.module

中导入HttpModule,如下所示

import { HttpModule } from "@angular/http";

然后在imports部分

中使用它

imports: [BrowserModule, ReactiveFormsModule ,appRouterModule,HttpModule]

但是,如果您正在使用Angular 4并希望使用新的HttpClientModule,这将在更高版本的角度中使用,那么您可以像下面一样使用它

你的app.module中的

进行以下更改

import { NgModule, PipeTransform }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { ReactiveFormsModule  } from '@angular/forms';
import { HttpClientModule } from '@angular/common/http;  //import the module here
import { AppComponent } from './_componant/app/app.component';
import { appRouterModule } from './app.route';
import { LoginComponent } from './_componant/login/login';
import { RegistrationComponent } from './_componant/registration/registration';
import { services } from './_utilities/services/services';


@NgModule({
  imports: [BrowserModule, ReactiveFormsModule ,appRouterModule,HttpClientModule],
  declarations: [AppComponent, LoginComponent, RegistrationComponent],
  bootstrap:    [AppComponent],
  providers: [services]
})

export class AppModule { }

在您的 service.ts 类导入并按下面的方式注入

import { HttpClient,HttpHeaders } from '@angular/common/http';

@Injectable()
export class services
{
    constructor(private http: HttpClient){ }
  /// rest of the code 
}