博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从Knockout到Angular的架构演变
阅读量:5796 次
发布时间:2019-06-18

本文共 2126 字,大约阅读时间需要 7 分钟。

2008年第一次在WPF中使用MVVM模式之后,就一直热衷于耦合隔离、模块化与重构、UI和逻辑分离、单元测试以及后面的领域模型。谈及MVVM模式,自己也开发过一套框架,但没有长期更新和维护,所以索性就一直使用Prism和MVVM Light。到2012年的时候,看到HTML5的大行其道和Silverlight的衰落,果断把主要精力投入到ASP.NET MVC和Knockout的开发和研究当中,虽然Knockout比较容易上手且方便使用,但总觉得没有在WPF和Silverlight中使用MVVM那么酣畅淋漓。

 

WPF/Silverlight

Web

MVVM框架

· Prism

· MVVMLight

· Caliburn(Caliburn.Micro)

· MVVM Helpers

· Cinch

· MVVMFoundation

· AngularJS

· Knockout (or use Durandal)

· Backbone.js

· Ember.js

· Epitome

· Agility.js

尽管后面尝试过其他框架,比如通过Durandal 实现SPA让我之前对Knockout的种种不便有所改观,但始终还是有所缺憾,直至现在使用Angular,尤其是Angular + TypeScript才发现一切问题都不复存在了。

(之前使用WPF/Silverlight的最大问题其实是很难招到合适的人员做美工和设计,因为很少人会专门投入到Blend和XAML的研究当中,但现在使用Web就会发现资源是那么的丰富,不管是人力资源还是开源社区)

功能

WPF/Silverlight

AngularJS

UI

XAML

HTML+CSS

设计工具 Design/Blend and Visual Studio All professional design tools

控件模板和自定义控件

Control Templates or Custom Control

Custom Directives (Element)

动画

System.Windows.Media.Animation

CSS3 Animations and/or JavaScript via ngAnimate

样式和模板

XAML/Resources

CSS3 and LESS

样式继承和关联

Implicit Styles and/or BasedOn

LESS Mixins

转换和过滤

IValueConverter

Filters

绑定Model到UI

ViewModel and DataContext

Controller and Scope

服务重用

Prism Service Locator

Custom Services/Service Factory

事件

Routed Events

$emit and $broadcast

模块化

MEF and/or Prism Module Catalog

Angular Modules

Services

WCF or WCF RIA Services

RESTful services (accessed via the Angular $http/$resource Services)

导航与路由

UriMapper

Routing

内部组件通信

Prism Event Aggregator  or Messager

Shared Services

视频

MediaElement

HTML5 Video Element

脱离浏览器运行

Yes

Yes, via Chrome Apps

封装UI逻辑

Behaviors

Custom Directives (Attribute)

UI与逻辑分离

Control or Data Templates

CSS/LESS

跨域请求

Access-Policy

CORS

单向数据绑定

BindingMode.One

Ng-Bind

双向数据绑定

BindingMode.TwoWay

Ng-Model

单向数据源绑定

BindingMode.OneTime

Ng-Model

开源模板

Modern UI or MahApps

Bootstrap or Foundation

浏览器支持

Need silverlight plugin or XBAP

All supported

所以现在将架构由Knockout到Angular的调整并使用到新项目的开发,具体如下:

https://images0.cnblogs.com/blog/47784/201408/312227322046408.png

 

 

到目前为止,还没有发现Angular有什么大的技术难题或者性能问题,如果有Angular项目经验的朋友,不妨留言讨论,学习共勉!

另外,很多人发邮件问WPF是否会像Silverlight一样消亡,其实这个问题很难回答,尤其在目前这个不光是微软主导的开发环境下(HTML5流行度远甚于XAML,IOS和Android的大行其道与Windows Phone的不温不火,Windows的命运尚不知晓),可能连微软自己也不能很好地解答这个问题,所以一切只能由市场和时间来慢慢决定。

转载地址:http://cpifx.baihongyu.com/

你可能感兴趣的文章
锐捷交换机密码恢复(1)
查看>>
Kali linux virtualbox rc=1908 错误解决办法
查看>>
Erlang学习总结之Erlang语法中的逗号(,)、分号(;),句号(.)的正确用法...
查看>>
linux软件包管理之三(源代码安装)
查看>>
数据库三范式是什么?
查看>>
[转载]设置Ubuntu自动连接无线,无须再输入密钥环和无线密码
查看>>
九叔Xen App测试报告
查看>>
Apache配置
查看>>
Ext gridPanel 单元格数据的渲染
查看>>
Android SDK 的下载代理
查看>>
Method Swizzling对Method的要求
查看>>
佛祖保佑,永不宕机
查看>>
四、配置开机自动启动Nginx + PHP【LNMP安装 】
查看>>
LNMP一键安装
查看>>
SQL Server数据库概述
查看>>
Linux 目录结构及内容详解
查看>>
startx命令--Linux命令应用大词典729个命令解读
查看>>
华为3026c交换机配置tftp备份命令
查看>>
Oracle命令导入dmp文件
查看>>
OCP读书笔记(24) - 题库(ExamD)
查看>>