微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Angular 9-错误:StaticInjectorError [Http]:StaticInjectorError [Http]:NullInjectorError:没有Http提供程序

如何解决Angular 9-错误:StaticInjectorError [Http]:StaticInjectorError [Http]:NullInjectorError:没有Http提供程序

我是Angular测试的新手。现在,我正在尝试测试服务。 当我为单元测试运行ng test时,以及当这些测试使用该服务时, 我收到错误消息:

Error: StaticInjectorError[Http]:  
StaticInjectorError[Http]: 
NullInjectorError: No provider for Http!

这是我的规格文件

import { Testbed,inject } from "@angular/core/testing";
import { ContactService } from "./contact.service";
import { HttpClientTestingModule,HttpTestingController } from '@angular/common/http/testing';
import {HttpClientModule} from '@angular/common/http';

describe("ContactService",() => {
  beforeEach(() => {
    Testbed.configureTestingModule({
        imports: [HttpClientTestingModule,HttpClientModule],providers: [ContactService],});
  });
  
  it("should ...",inject([ContactService],(service: ContactService) => {
    expect(service).toBeTruthy();
  }));
});

这是我的.sevice.ts文件导入:

import { Headers,Http } from '@angular/http';
import 'rxjs/add/operator/toPromise';
import { Contact } from '../';

解决方法

您正在从http注入@angular/common模块,但是您已经导入了@angular/http模块。

更改为此:

import { Headers,Http } from '@angular/common/http';

而您只需要这个:

imports: [HttpClientTestingModule],

或者代替实际的ContactService,您可以对其进行模拟:

class MockContactService {
   // properties and methods to mock
}

现在您可以在提供商中使用它了

providers: [
   {
     provide: ContactService,useClass: MockContactService
   }
]

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。