重新学习web后端开发-005-了解前后端分离开发模式

005-01.jp

分离是为了以后更好的相聚。- 匿名

1. 什么是前后端分离

在作者早期参加工作时,web项目开发基本上是程序员加美工的组合,那个时候还没有明确的前后端的说法。一个web项目就像一道大杂烩,包括了界面和后端业务逻辑,同时前端的页面由后端进行渲染。

早期web项目结构

随着Ajax,尤其是nodejs的发展,前端的能力大大增强,工程化也越来越成熟。很多之前需要后端去做的事情,比如页面的渲染,前端已经完全可以胜任。并且前端也不仅仅局限于pc桌面,而是发展到移动端,tv等。近年来,前后端分离开发逐渐流行开来,尤其是在互联网方向,已经成为了主流的web开发方式。

前后端分离开发

2. 前后端分离的优点

2.1 优点一:分工明确

专业的人做专业的事情。前后端分离后,前端人员可以专注于UI界面的设计开发,后端人员则可以专注于业务逻辑开发,提供前端调用的API接口。

2.2 优点二:解除耦合

将前端UI界面和后端服务数据分离,可以将后端服务接口独立出来,服务于不同的前端UI,比如传统PC桌面,移动端H5,APP等,提高了后端服务的可复用性和可维护性,同时也有利于向分布式微服务架构进行演变。

2.3 优点三:提升效率

前后端未分离web开发模式如下图:

前后端未分离web开发模式

我们可以看到,程序员要等待美工先导出html模板后,再开始整合模板,渲染页面。程序员承担了大部分的工作,包括页面的二次处理(数据渲染、页面整合等)以及后端业务逻辑的开发工作。

前后端分离后web开发模式

前后端人员可以同时进行开发,互不干扰。双方遵循统一的规范(产品原型及API接口文档),各自进行独立的开发,开发完成后进行联合测试(俗称联调)。

3. 前后端分离后产生的主要问题

3.1 沟通成本上升

前后端分离前,程序员承担了大部分前端页面渲染和后端业务逻辑的工作,基本上没有太多的沟通成本。前后端分离后,前端需要承担页面设计和数据渲染的工作,数据需要通过调用后端提供的接口服务来获取。这样一来,统一的接口文档就成为前端和后端的主要契约,随着需求的调整以及项目的快速迭代,接口也会随之出现变动,这时双方之间的沟通成本将大大增加。如果没有良好的沟通机制和统一的接口文档管理将会导致双方扯皮,互相推诿,影响产品周期和团队建设。

那么如何解决这个问题呢?简单来说就是:统一规范!也就是统一沟通机制以及接口文档管理。主要有以下几点建议:

  • 接口文档由前后端中的一方进行统一管理。另外一方必须根据接口文档开展相应的工作。

    至于是由前端去管理还是后端去管理,可以综合团队前后端人员的能力、业务理解程度等方面情况来决定。

  • 对接口文档的变更操作,必须要先体现在接口文档中,并通知到相应人员。切记不要事后再去更改文档!

  • 定期会议沟通,可集合团队具体的沟通机制进行。

  • 使用接口文档管理系统,对接口进行统一的管理。同时很多接口文档管理系统还会提供接口版本管理、mock server,接口测试等功能。

    推荐使用YAPI接口管理系统,可以为开发、产品、测试人员提供更优雅的接口管理服务。具体使用详见其官网。

3.2 前端模拟后端接口问题

前端需要有一个能够模拟接口及其数据的服务,这样前端的开发进度就不依赖于后端的开发进度,双方就可以根据统一的接口文档各自开展工作,而统一的mock server就比不可少了。上面推荐的YAPI接口管理系统,就可以提供相应的mock功能。

这里需要注意一个问题,那就是mock server很难完全覆盖到后端所有的接口业务逻辑。这也是为什么需要联调的原因。毕竟mock的环境与真实的环境还是存在一定的差异。不过只要根据规范来做,可以大大提高联调的效率,节省时间。

3.3 测试介入太晚,拉长产品周期

针对这个问题,作者的经验是只要接口文档确定好,测试就可以根据接口文档写对于的接口测试用例了,同时还可以和一些接口测试自动化工具结合在一起,而不必等到联调完成后才介入。

总的来说,在互联网、移动互联网等大部分web相关方面,可以优先考虑采用前后端分离的方式进行web项目的开发。当然,没有任何的技术、框架或者方案是银弹,能够一招走天下,我们需要综合考虑项目、团队、成本等多方面因素,采用合适的方案。

4. 小结

本节主要介绍了前后端分离的基本概念、优点、实践中存在的问题以及对应的解决思路和建议。从下一节开始,我们将结合实际的案例开始一步一步的实战探索web后端接口开发的过程及其细节。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容