AngularJS与服务器端MVC比较

这是一篇讨论客户端MVC和服务器端MVC的比较文章。 首先分离关注是架构设计的一个基本原则,多层架构中:数据存储 服务层 API层和表现层各层之间应该最小依赖,服务层只需要知道在哪里存储数据,API只需要知道哪个服务被调用,而表现层主要是通过REST和API通讯。多层之间只能单向依赖,比如API不能知道是谁调用它,它不能依赖于表现层。(可见:干净的架构) 在真实情况下各层情况比较复杂,但是分离关注在随着机器和设备(laptop, mobile, tablet, desktop)增加越发重要,后端应该只提供业务逻辑和数据。 过去,MVC主要是在服务器端实现,主要语言有 Java和C#等,如今客户端MVC已经出现,如AngularJS BackoneJS和EmberJS等。 服务器端MVC框架容易使用,有许多选择和成熟的解决方案,后端编程语言选择有 Java, Scala, C#, Clojure, JavaScript/NodeJS, 等等,其实我们并不需要在浏览器方面的豪华阵容,Adobe Flash已经死了, Silverlight 从来没有雄起,因为Html5到来了,浏览器世界变化很快。 如果再考虑到移动设备开发,并没有一种原生语言适合所有设备,所以,使用Html也许是一种解决方案。 所有这些都有一个共同点,无论是移动 Web 或桌面,或Google眼镜,所有的设备都要和后端API通过REST通讯。 下面看看AngularJS的缺点和优点: 1.页渲染: Angular.JS在页渲染方面是慢的,需要对DOM做额外一些工作,需要监察绑定数据的变化,实现额外的REST请求,第一次应用打开时,它需要下载所有JavaScript文件。当然随著计算机和移动设备计算能力提高,这些问题会消失。 2. 兼容性:老的浏览器很难适应Angular.jS ,目前只支持到IE8,可以针对老浏览器推出特别页面。 3.SEO:这可能是最大问题,(banq注:使用CQRS读写分离可以很好解决这个问题,读方面不使用Angular,使用标准的URL,可见:http://www.jdon.com/46502) 以上是缺点,AngularJS优点是: 1.提升服务器性能,因为使用JSON数据格式和客户端缓存,客户端和浏览器的流量大大降低,服务器端不需要在发送响应到客户端之前创建JSP/ASP页面了,它只需要服务静态文件和响应API调用,并以简单的JSON格式返回,服务器端负载降低了。 在前端完全解耦后端方面,Angular只需要知道后端REST API,这种解耦允许我们开发出前端和后端独立的应用,浏览器消费后端API方式同样适合Andoird iPhone等移动设备。当我们开发前端应用时,后端编程语言不再需要了,只需要HTML/CSS/JS,这对大多数前端开发者是一种解放。前端开发者可以开发出页面互动和用户体验更棒的应用。 当然,如果在服务器进行页面渲染可以避免进入 HTML, CSS 和 JavaScript细节. 能和后端编程语言一起工作,这样可能没有必要学习太多浏览器语言。它也会和后端产生耦合。会制约前端开发者在美工和创意方面的发挥。 下图是一张基于RESTful微服务和客户端MVC和服务器端MVC的架构图:

原文发布于微信公众号 - 交互设计前端开发与后端程序设计(interaction_Designer)

原文发表时间:2016-02-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏我和我大前端的故事

入门微信小程序 (一)

小程序已经快两岁的,我才入坑,刚刚入坑那会我使劲和我朋友抱怨,太难了,学不动,不想学,不学了。硬着头皮死磕一遍文档,然后觉得也没有我想象中那么难。或许是因为语言...

28420
来自专栏腾讯社交用户体验设计

QQ Mac版 Touch Bar功能设计

17610
来自专栏知晓程序

终于过审!首批小程序插件诞生了

18620
来自专栏IT大咖说

前端老牌框架衰退,IMVC(同构 MVC)成未来趋势?

18520
来自专栏hbbliyong

opoa介绍

一 定义       One Page, One Application(后面缩写为OPOA,或者1P1A), 含义很简单:一个页面就是一个应用。不再使用ifr...

35270
来自专栏编程微刊

小程序新方法 open-type获取头像昵称

小程序自上线以来,官方一直在调整API,因此也出现了一批被废弃的接口,作为程序员的我们,此时此刻千万不能为这不断的变化而感到头疼,应当与时俱进,不断的更新自己的...

42720
来自专栏企鹅号快讯

小程序也有“home”键盘了!

微信小程序最近仿佛是消停了一会儿儿,没有深夜袭击,不过还是有不断地小更新,今天就来给大家唠叨两个新变化。 --小程序安卓用户更新 12月22日,微信更新了安卓版...

24950
来自专栏织云平台团队的专栏

织云Lite V1.3| 教你用标签轻松管理设备集

17240
来自专栏ytkah

wamp支持win10吗?怎么设置?

  上周ytkah总算把系统升级到win10了,可怎么设置wamp支持win10呢?启动wampwerver是处于黄色状态,打开本地页面是空白,应该是端口问题。...

36790
来自专栏移动端开发

iOS 即时通讯 + 仿微信聊天框架 + 源码

更新:2017年8月1日 实在是抱歉,git上的Demo这么久,有问题自己没有发现!肯定给大家造成过不方便,抱歉!git上Demo刚重新上传,要有需要的可以去...

1.2K50

扫码关注云+社区

领取腾讯云代金券