由于其双向数据绑定功能,角色或多或少遵循MVV *设计原则.
Angular2正在采用基于组件的UI,这是React开发人员可能熟悉的一个概念.在某种意义上,角度1.x控制器和指令模糊到新的角度2组件.
这意味着在Angular 2中没有控制器,没有指令.相反,组件具有与组件将要表示的html标签相对应的选择器,而@View指定要填充组件的HTML模板.
Angular2仍然实现双向数据绑定,但不包括模型,例如,如果我有一个@Component显示文章列表和定义文章对象的类:
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 2跟随最近的设计模式呢?
角1&角度2跟随MVC(模型,视图,控制器)模式.
在角度1中,HTML标记是View,Controller是Controller&该服务(当它用于检索数据时)是模型.
在角度2中,模板是View,类是Controller&该服务(当它用于检索数据时)是模型.
因为Angular是一个客户端框架,所以MVC模式Angular可以被称为MVVC(Model,View,View Controller).