- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正面临一个 angular2 软件设计问题,我不知道什么是更好的解决方案:
在 ngOnInit 中获取 REST 数据还是使用解析器?
我从来没有遇到过在 ngOnInit 方法中获取数据的问题,但现在我听说过解析器,但我不确定该使用什么:
ngOnInit() {
this.authHttp.get('http://localhost:8080/configuration')
.map((response: Response) => <ConfigurationData>response.json())
.subscribe(settings => this.settings = settings);
}
对比
@Injectable()
export class ConfigurationsResolver implements Resolve<ConfigurationData> {
constructor(private authHttp: AuthHttp) {}
public resolve(route: ActivatedRouteSnapshot): Observable<ConfigurationData> {
return this.authHttp.get('http://localhost:8080/configuration')
.map((response: Response) => <ConfigurationData>response.json());
}
}
解析器会生成更多代码。额外的类,声明一个提供者等等。
那你怎么看?对此有何陈述和最佳实践?
最佳答案
服务方法在单一职责原则和可测试性方面更加简洁。
假设您的业务层组件之一需要配置。所以它的需求可以表达为“我需要配置”。它不关心如何获得它,从哪里获得它等等——它所需要的只是配置数据,仅此而已。因此,为了获取此数据,组件现在表达了另一个查询 - “我需要知道如何为我获取配置数据的人”。这是您注入(inject)服务的地方。主要组件不关心此数据是硬编码的、从服务器获取的还是从随机生成器以某种方式派生的——这不是它的事。所以你的主要组件不维护任何与其任务无关的逻辑,你的配置 getter 也不维护任何关于如何处理这些数据的逻辑。他们每个人都有严格的责任。
这样可以轻松测试它们。您可以轻松地模拟配置数据 getter 组件并将其注入(inject)到您的主要组件中。它为您提供了在易于控制的条件下测试主要组件的简单方法 - 您的模拟组件允许您测试主要组件如何处理获取正确数据、不正确数据、调用失败等 - 因为它是您的模拟,所以它可以帮助您模拟任何你想要的。
关于 Angular 2 : fetching REST-data with ngOnInit vs Resolver,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41264764/
我使用 resolver() 作为 socket() 的替代方法,因为我发现当多个连接建立到不同的 IP 时,它最终会停止工作。 无论如何它会向我返回一个警告,我应该使用 dns.resolver.R
我有这个代码: var promise1 = new Promise(function(resolve, reject) { setTimeout(() => { console
我仍在学习 PHP,我认为我不是母语人士,这并不难理解。 此时,看了一大堆文档,跳入了深水区,于是打开Laravel源文件,一个接一个地看,试图更好地理解MVC的整个实现,包括路由、中间件如何组合成一
public JsonResult GetEvents(double start, double end) { var userName = Session["UserName"] as st
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
我写了下面的代码: function readFile(path) { return new Promise(function(resolve, reject){ if(!fs
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
在某处读过这个例子: return new Promise( (resolve, reject) => { fs.readFile(file, (err, data) => { if (e
我刚开始学习 React,我一直在尝试让我的 React 应用程序连接到我的数据库 var mysql = require('mysql'); var con = mysql.createConnec
我需要从 $http 调用中返回一个 promise 中的自定义响应,以便我可以链接更多调用。我有两个可用的实现。有人可以解释两者之间的区别,并争论其中一个更好吗? 在 fooService.js 实
免责声明:这里实际上提出了两个问题,但我觉得它们密切相关。 我正在尝试将 promise 对象传递给指令,并且我想在 promise 解析后立即在指令中运行一些初始化代码。 在我的 Controlle
我正在尝试创建类似于 this code 的东西在 boost.asio 示例中找到。 套接字.h: class some_class { private: ... boost
正如我们所知,Promise 构造函数采用一个执行函数,该函数具有两个参数,我们使用它们来生成成功案例或失败案例。今天我在编程,我被卡住了,但后来我解决了这个问题,但我发现了一件事需要理解。 有什么区
我认为 Promise.resolve 和 new Promise(resolve) 可以互换。 考虑一下: A. new RSVP.Promise(function (resolve, reject
我下载了一个 Java 项目,我想研究并从中学习一些东西。当我在另一台计算机上下载它时效果很好,但是当我在我的计算机上尝试时,几乎每个声明和导入都会给出错误消息“* cannot be resolve
我昨天看到了一些有趣的编译器行为,我想我明白为什么会这样,但我想确定一下。所以,我不会写我的推理,只写事实。 请注意,我使用 vector 而不是 string 并不是错字。我是故意这样做的,这样编译
我正在尝试运行 Ember 测试,它给出了这个错误,提示无法找到从 `AppName/resolver 导入的模块 ember-resolver。 我不确定是什么原因造成的。我正在使用 Ember-c
Code#1 和 Code#2 的区别在于:Code#1 使用 resolve(p) 而 Code#2 使用 p.then(()=>resolve()) 。我希望输出序列是不变的,但它们会生成不同的序
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
我是一名优秀的程序员,十分优秀!