Java Web开发中前后端分离的技术方案和优缺点

方案一

前端使用AngularJS编写SPA(Single Page Application)应用,后端服务器只提供RESTful接口且完全无状态化。
优点:
前后完全分离,前端开发者完全不需要关心服务端用了什么技术,只需要一份接口说明文档即可。
手机App与PC端网站可以共用同一套接口。
缺点:
如果”页面”过多,SPA应用第一次加载速度会稍慢。
SEO困难。

方案二

使用NodeJS渲染Web页面,然后调用后端RESTful接口。
优点:
前后完全分离, 后端开发者可以专注于业务逻辑开发。
缺点:
NodeJS代码如果异常处理不好容易直接挂掉进程。
增加了部署和维护成本
对前端开发者技术要求比较高
增加了一层NodeJS,提高了网络传输的开销

方案三

使用Velocity(或其它渲染引擎),前端开发者只写静态页,完成后交给后端进行“动态化”
优点:
前端完全不需要关注后端的任何东西。
缺点:
后端开发者必须熟悉HTML , CSS, JS,不能专注业务开发。
前后端沟通成本大
后端服务器如果需要为App提供接口,则需要写两套Controller

方案四

前端开发者学习使用Velocity语法,直接编写*.vm文件
优点:
后端完全不需要关心页面问题
缺点:
前端人员学习成本高
需要在本地搭建、部署Java运行环境,对前端人员来说难度很大。
后端服务器如果需要为App提供接口,则需要写两套Controller。

Web研发模式演变
Web系统开发构架再思考-前后端的完全分离
说说JSON和JSONP,也许你会豁然开朗

你可能感兴趣的:(网页开发)