当前位置:  开发笔记 > 运维 > 正文

如何在Angular 2中为开发(而不是测试)提供模拟服务?

如何解决《如何在Angular2中为开发(而不是测试)提供模拟服务?》经验,为你挑选了1个好方法。

我需要一种方法来在Angular 2的开发期间(而不是在测试期间)模拟我的服务.原因是REST-ful服务器不可靠(更改API而不通知,不稳定,难以擦除并再次站起来) .如果我可以模拟我的服务(基本上都是HTTP REST客户端),那将是很好的.

在Angular 2中创建模拟后端服务的最佳方法是什么?我在测试方面有很多关于模拟后端服务的互联网结果,但这个上下文不是我的用例(我不是在嘲笑测试而是开发).

我已经使用了角度cli来创建和支撑我的项目,我不确定该工具是否可以提供帮助.

我正在寻找像Spring这样的方法,我们可以用"profiles"注释组件/类,然后方便地指定哪个配置文件是活动的,以便注入正确的依赖项.



1> alex kucksdo..:

我认为实现目标的最佳方法是使用接口和服务提供商.我希望以下示例代码可以指出您正确的方向:

数据tables.service-interface.ts

export interface DataTablesServiceInterface {
    getHeaders(): Promise;
    getData(query?: string, offset?: number, size?: number): Promise;
}

数据tables.service-provider.ts

import { Http } from '@angular/http';
import { OpaqueToken } from '@angular/core';

import { DataTablesServiceInterface } from './data-tables.service-interface';
import { DataTablesService } from './data-tables.service';
import { DataTablesMockService } from './data-tables.mock-service';

import { environment } from '../../../environments/environment';

let dataTablesServiceFactory = (http: Http) => {
    var serviceToReturn: DataTablesServiceInterface;
    if (environment.production) {
        serviceToReturn = new DataTablesService(http);
    } else {
        serviceToReturn = new DataTablesMockService();
    }
    return serviceToReturn;
};

export let dataTablesToken = new OpaqueToken('DataTablesServiceInterface');

export let dataTablesServiceProvider =
    {
        provide: dataTablesToken,
        useFactory: dataTablesServiceFactory,
        deps: [
            Http
        ]
    };

您只需要实现实际和模拟服务,并可以根据已使用的angular-cli中实现的嵌入式配置文件机制提供它们environment.

编辑: 还有一些我忘了提及的信息.在您的负责模块中,您需要声明dataTablesServiceProvider为提供者.在您要使用该服务的组件中,DI的方法与标准方法略有不同.

在组件的构造函数中,您编写以下内容:

constructor(@Inject(dataTablesToken) private dataTablesService: DataTablesServiceInterface)

如果你对不透明的标记感兴趣,我建议你看一下Angular的Opaque Token

推荐阅读
勤奋的瞌睡猪_715
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有