RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 896489
Accepted
A. Victor
A. Victor
Asked:2020-10-23 00:59:03 +0000 UTC2020-10-23 00:59:03 +0000 UTC 2020-10-23 00:59:03 +0000 UTC

Angular 2 正确和不正确地使用服务和组件模块?

  • 772

首先,非常感谢您。现在有2个问题第一个关于结构的问题。我是新来的。我阅读了有关模块、组件、服务的内容,但我仍然不完全理解这些实体中的每一个中哪些任务是固有的,哪些是外来的。我将特别感谢这种形式的回答:这些是模块的任务,但这些是模块不可能的,最好将其委托给组件。等等。是否可以让一项服务完成向不同服务器发出两个请求的任务,还是我需要编写两项服务?为什么?

第二个问题是实用的。我正在编写一个查询天气 API 的课程。用户输入cityName。我将第一个请求发送到 json 文件所在的服务器,我即时发送名称,我得到名称中具有相同字母的城市列表。我正在为用户制作一个实时下拉工具提示。

例如:你输入了 kongo,出现一个提示:

    0: "{"id":202239,"name":"Gikongoro, RW"}"
    1: "{"id":1064234,"name":"Ikongo, MG"}"
    2: "{"id":212360,"name":"Kongolo, CD"}"
    3: "{"id":2359142,"name":"Kongoussi, BF"}"

然后在用户点击所选城市后。我将它的 id 发送到天气服务器。我从 API 获取 json 天气。我画出答案天气预报。

问题:在这个应用程序的最佳结构中应该有多少和哪些模块,哪些组件和服务应该有什么任务?我提前发誓。

angular2
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    overthesanity
    2020-10-23T02:14:19Z2020-10-23T02:14:19Z

    您的问题并不完全清楚,但我会尽力回答,因为您自己知道正确的问题是答案的一半。

    Angular 中的模块是一个相当复杂的话题,但我将尝试用简单的术语来解释。Angular 中模块的概念主要是为了实现“关注点分离”的原则。每个模块都是一个黑盒子,封装了一定的业务逻辑。当然,在实践中,模块通过按需加载(延迟加载)的能力来提高大型应用程序的性能。模块没有任何任务,您不需要为它们分配任何东西或编写任何代码,模块没有生命周期。模块的目的主要是编译其中声明的组件declarations,每个模块都有自己的类实例Compiler,由于模块的次要目的是管理DI机制(依赖注入),在运行时模块也是一个注入器。

    @NgModule()
    export class AppModule {
        constructor(injector: Injector) {
            console.log(injector.constructor.name === 'NgModuleRef_'); // true
        }
    }
    

    如果您将令牌的依赖项注入Injector到模块中,那么模块将收到指向自身的链接。

    Google 团队,即 Misko Heveri(Angular 团队负责人),决定在开发 Angular 1.x 时让人们有机会使用 SCA 架构(服务组件架构)。如果我们现在谈论的是 Angular 2+,那么服务还有一个目标是隔离可以在组件之间翻找的逻辑reusable。任何服务都必须做一些特定的事情。

    你可以将所有的逻辑完全写在一个组件中,然后从组件发出请求,操作大数据,但这一切都破坏了设计,而分解才是最重要的。在组件中,您只需要实现数据更新逻辑。

    在 Angular 的情况下,VM(视图模型)是数据和最终用户看到的视图之间的中间层,VM 的任务是更新模型,您将其余逻辑交给服务。Можно ли одному сервису дать задачу делать оба запроса на разные серверы или нужно писать два сервиса?- 由您自行决定。

    升级版:

    没有组件架构之类的东西,只有应用程序架构。关于您的“天气预报”应用程序,我将只创建 1 个服务来使用 API,我会调用它WeatherService,以及几个组件,一个用于在用户选择城市后显示天气的组件、一个搜索组件和一个提示组件。所有应用程序都没有特定的结构,Angular 是一个同构平台,允许您设计任何复杂的架构。一旦确定了问题/提出了要求/制定了设计计划,所有这些高级设计就会发挥作用,这一切都是非常情景化的。

    在图中,组件没有给出任何东西,这些箭头原则上可以称为委托,但实际上它们表明组件不直接与状态管理器通信,而是使用中间层(intermediary),尽管反过来,经理在工作完成后,可以通知组件一些信息。该图是当今任何企业 Angular 应用程序的一个小基础,每个人都从它开始。

    • 3

相关问题

  • 如何在角度2的组件之间传递数据

  • Angular 2 EventEmitter 事件被调用但数据未更新

  • Angular2 应用程序缩小。加载时间优化

  • 如何摆脱错误“类型‘订阅者[]’上不存在属性‘数据’”?角度 2

  • 根据角色删除页面元素?

  • 如何将多个订阅者订阅到一个观察者

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5