- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
Angular 1.x (AngularJS) 或多或少遵循 MV* 设计原则,因为它具有双向数据绑定(bind)功能。
Angular2 正在采用基于组件的 UI,这个概念对于 React 开发人员来说可能很熟悉。从某种意义上说,Angular 1.x Controller 和指令模糊到新的 Angular 2 组件中。
这意味着在 Angular 2 中没有 Controller 也没有指令。相反,一个组件有一个选择器,它对应于该组件将表示的 html 标记和一个 @View 来指定要填充的组件的 HTML 模板。
Angular2 仍然实现双向数据绑定(bind),但不包含模型,例如,如果我有一个显示文章列表的 @Component
和一个显示文章列表的 class
定义文章对象:
class Article {
title: string;
link: string;
votes: number;
constructor(title: string, link: string, votes?: number){
this.title = title;
this.link = link;
this.votes = votes || 0;
}
这在 MVC 模式中将被视为模型。
那么考虑到这一点,Angular
最接近哪种设计模式?
最佳答案
Angular 2 并不是真正的 MVC(但我想你可以画出相似之处)。它是基于组件的。让我解释一下:
Angular 1 是 MVC 和 MVVM (MV*)。 Angular 1 具有开创性有几个原因,但其中一个主要原因是因为它使用了依赖注入(inject)。与 Backbone 和 Knockout 等其他 JS 框架相比,这是一个新概念。
然后 React 出来了,彻底改造了前端架构。它让 Front End 更多地考虑 MVC 和 MVVM 之外的其他选择。相反,它创造了基于组件的架构的想法。这可以说是自 HTML & JavaScript 以来前端架构最重大的变革之一。
Angular 2(和 Angular 1.5.x)决定采用 React 的方法并使用基于组件的架构。但是,您可以在 MVC、MVVM 和 Angular 2 之间画出细微的相似之处,这就是我认为它可能有点令人困惑的原因。
话虽如此,Angular 2 中没有 Controller 或 View 模型(除非您手工制作它们)。取而代之的是组件,它们由模板(如 View )、类和元数据(装饰器)组成。
例如,模型是保存数据的类(例如,使用@angular/http 保存由 http 服务返回的数据的数据契约)。我们可以创建一个新类,添加方法和属性(逻辑),然后合并模型和类。这会创建类似于 ViewModel 的东西。然后我们可以在我们的组件中使用这个 ViewModel。
但是将组件的类或服务称为 ViewModel 或 Controller 并不正确。组件包含模板和类。 IMO 这有点像 Liskov 的理论——鸭子不是鸭子——不要试图将 MVC 或 MVVM 模式强加到组件中,因为它们是不同的。将 Angular 2 视为组件。但我明白为什么人们会通过相似之处来帮助他们初步理解。
Angular 还使用模块,它是即将发布的 JavaScript 版本 (ECMAScript 6) 的一部分。这非常强大,因为 JavaScript 在命名空间和代码组织方面一直存在问题。这是导入和导出组件的地方。
有用的链接:
https://medium.com/javascript-scene/angular-2-vs-react-the-ultimate-dance-off-60e7dfbc379c
关于Angular 设计模式 : MVC, MVVM 还是 MV*?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36950582/
我已经对这个主题进行了一些研究,并且已经在少数应用程序中使用了 MVVM 模式。 我问这个问题是因为有时 MVVM 被称为设计,有时被称为架构模式。 在大多数情况下,MVVM 模式称为设计模式。但是就
我开始使用 MVVM Light 版本 4,但我无法理解: 为什么要使用 DataService 和 IDataService? 我应该为模型中的任何类创建数据服务吗? 最佳答案 首先 - 像往常一样
是否可以采用MVVM在一个平台(如 windows phone)中设计模式并以可移植到其他平台(如 android 和 iOS)的方式实现代码的数据绑定(bind)? 或者我最好问问MVVM设计模式在
使用 avalondock在 MVVM 环境中似乎相当具有挑战性。一旦我从 shellview 中分离 DocumentPane,我就会丢失相应的数据上下文并且我的 View 是空的。重新连接时,它会
我对避免背后代码中的代码的方法很感兴趣。 在我看来,有些情况下代码必须放在代码后面。 例如:我有一个未定义列数的网格。无法绑定(bind)列。所以最简单的方法是在后面的代码中生成列。 对于这种情况,我
我熟悉MVVM。实际上,我在SL4中进行了大部分学习。但是,由于最近的需求,我必须使用SL3。我试图将MVVM Light v3与SL3结合使用并利用命令。问题是在SL3中没有按钮的Command属性
UI逻辑在WindowsRT MVVM应用程序中应该在哪里?将其放到ViewModel上真的很“胖”,我想我们失去了MVVM模式的优势之一-在设计人员和程序员之间分配工作变得非常困难。但是,我创建了一
您好,我有 3 个关于 MVVM 模型的问题。 有没有办法绕过那个多余的PropertyChanged("PropName"); 将 POCO 对象包装到 WPF 的最佳方法是什么 INotifyPr
我正在使用 MVVM 模型做一个 Silverlight,我发现很难通过 MVVM 进行事件处理,尤其是事件处理程序在 View 中进行了大量更改,例如启用和禁用按钮、更新媒体元素功能和位置。我还是
我有一个测试应用程序来测试 windows phone 8.1 上的导航,我可以从主页到第二页进入第二页。 问题是,当我单击后退按钮时,我返回桌面屏幕并且应用程序进入后台,所以我必须按住后退按钮才能返
我正在尝试使用并选择好的MVVM Framework,并且其中有很多,因此选择确实很困难。 我想知道其中的2个-CinchV2(Sacha Barber)和MVVM Light Toolkit(Lau
我完全不熟悉Windows 8开发,现在遇到使用MVVM Light混合触摸和键盘导航的问题。 所以,我有个 View 模型的列表,在网格 View 和只要选择其中的一个,导航到选定的 View 模型
我最近下载了MVVMExtraLite,并且有一个名为 Mediator 的帮助程序。我听说过 Messenger (在MVVM Light中)。有什么区别吗? 最佳答案 他们使用相同的模式,即调解员
我正在尝试学习MVVM,并且在区分模型和 View 模型方面有些挣扎。 如果有人可以回答这两个问题,那么对我来说将大有帮助: 说我有一个Objects类,这是一个包含Object的多个Observab
我已经在网上进行了一些研究,并且得出了一些矛盾的答案。这是我的情况: 我有一个引用ClientViewModel的EditClient View ,还有一个还引用ClientViewModel的Add
我正在使用带有 ModelView-First 方法的 MVVM 模式。到目前为止,这工作正常。 现在我有一个用户控件( View ),它应该根据位于我的 ViewModel 中的属性显示各种内容。
我必须创建一个对话框,其中必须在运行时生成列,之前我使用的是 WPF 数据网格,因此在运行时生成列不是问题。现在我必须使用 View 模型,我需要为要在 View 中显示为列的任何字段具有属性。列数在
所以我目前正在使用 Xamarin.Forms 开发一个应用程序。 Xamarin Forms 使用 MVVM 模式,我觉得使用这种模式有点舒服,但我确实有一些问题。为了简单起见,我将使用一个单页应用
是否有在MVVM应用程序中使用Autofac的示例?我不确定在MVVM环境中如何控制生命周期和对象处置。 我知道我可以创建一个生命周期并从其下解决,但这确实更像是服务定位器模式而不是IoC模式。 最佳
我想我遗漏了一些简单的东西,但我找不到任何例子来说明如何做到这一点......另外,如果我使用的某些术语是错误的,请原谅我。 我只想使用绑定(bind)到 Kendo Observable 对象的 H
我是一名优秀的程序员,十分优秀!