Web前端开发中的MCRV模式.docx

上传人:b****3 文档编号:12910712 上传时间:2023-04-22 格式:DOCX 页数:16 大小:95.26KB
下载 相关 举报
Web前端开发中的MCRV模式.docx_第1页
第1页 / 共16页
Web前端开发中的MCRV模式.docx_第2页
第2页 / 共16页
Web前端开发中的MCRV模式.docx_第3页
第3页 / 共16页
Web前端开发中的MCRV模式.docx_第4页
第4页 / 共16页
Web前端开发中的MCRV模式.docx_第5页
第5页 / 共16页
点击查看更多>>
下载资源
资源描述

Web前端开发中的MCRV模式.docx

《Web前端开发中的MCRV模式.docx》由会员分享,可在线阅读,更多相关《Web前端开发中的MCRV模式.docx(16页珍藏版)》请在冰豆网上搜索。

Web前端开发中的MCRV模式.docx

Web前端开发中的MCRV模式

 摘要

  针对前端开发中基于ajax的复杂页面开发所面临的代码规模大,难以组织和维护,代码复用性、扩展性和适应性差等问题,本文尝试以MVC思想为基础,结合Web前端开发中“内容-结构-表现-行为”相分离的开发标准,提出一种将Web页面代码分为视图(View,页面静态部分,包括内容、结构、表现)、模型(Model,负责数据缓存、数据校验与本地逻辑处理、发起ajax请求)、控制器(Controller,负责用户和系统事件响应、模型和渲染器调度)、渲染器(Renderer,对视图的渲染,控制器与事件的绑定、数据搜集)的页面开发新模式,并基于此模式提出了一个开发框架原型。

  关键字

  MCRV设计模式,Javascript,MVC,Web开发标准

  1.Web前端开发面临的问题

  早期的Web页开发(Web前端开发)中,Web页面较为简单,大多数Web页面的功能仅限于用HTML和简单样式展示静态信息,或向服务器发送数据,Web页面与用户的交互较少。

随着Web的发展,DHTML、CSS、javascript等技术出现,Web页不再仅限于展示静态信息,动态、交互成为Web页的主流功能之一。

与此同时,Web页代码规模也变的较大,页面中的HTML、CSS、Javascript等代码往往混杂在一起,如何很好的组织这些代码,使Web客户端程序具有很好的结构,易于阅读和维护,成为Web前端开发人员面临的一个难题。

在实践中,业界提出了“内容(Content)-结构(Structure)-表现(Presentation)-行为(Behavior)”相分离的Web页开发标准。

在这种标准中,一个Web页代码可以分为如下四个部分:

  内容:

页面实际要传达的真正信息,包含数据、文档或者图片等。

结构:

对内容的划分,使内容更加具有逻辑性,易用性;类似页面的标题、作者、章、节、段落和列表。

表现:

用来描述内容外观,称之为“表现”,主要指CSS样式。

行为:

行为就是对内容的交互及操作效果;行为控制主要通过javascript实现。

  内容-结构-表现-行为(CSPB)开发标准对Web页包含的的代码进行了分类,使代码各个部分得到很好的分离,使Web页初步具有了良好的结构。

  随后,Web进入了崭新的Web2.0时代,以Gmail为代表的Web2.0应用大量出现,并且取得很大的成功。

这类Web页的典型特征是用一个基于ajax技术的无刷新的页面完成大量复杂的功能。

此类页面包括WebIM、WebMap、Gmail等应用,统称为one-pageWeb应用。

同时,在企业级Web开发中,一个Web页同时完成多个复杂功能的情况也越来越多。

在这些复杂Web页应用中,Javascript代码是此类富客户端应用程序的核心,负责与用户的复杂交互和页面展现。

One-pageWeb页面Javascript代码规模往往非常庞大,逻辑复杂,动则千行以上,有时甚至需要一个团队来完成一个页面的开发。

如何合理组织大量的Javascript代码,使之具有良好的扩展性,能够适应需求的变化,使代码易于维护,是广大Web前端开发人员面临的一大挑战。

  纵观Web应用程序开发的历史,Web后端开发(PHP、J2EE、ASP.NET)与Web客户端开发的发展过程有一定的相似性,曾面临类似的问题。

最初,Web程序功能简单,代码较少时,所有的控制、逻辑、UI展现代码混杂在一起;随着Web发展,程序规模变大,按原有方式开发出的程序显然不具有良好的结构,不利于大规模开发和后期维护,也不利于Web开发人员工作和角色的进一步细分,代码复用性差,瓶颈开始出现。

Web后端程序设计者的解决方法是进行代码分类,将控制代码与展现代码开始分离,于是Web后端开发从所谓的Model1发展到Model2;同时,传统桌面程序设计中的MVC(模型-视图-控制器)设计模式被引入,负责程序数据与逻辑计算的部分进一步分离出来,形成了Web后端开发中的MVC开发模式。

MVC设计模式贯穿了软件工程分而治之的思想,有效解决了Web后端程序设计中的代码组织和复用问题。

采用同一设计模式(MVC)也使代码更容易被他人理解,保证代码可靠性;它使Web开发工作可以细分为业务逻辑开发和UI展现开发。

因此,MVC也利于团队开发。

那么,MVC设计思想是否也能应用在前端开发中解决相关问题呢?

既然问题具有许多相似性,笔者沿着相同的解决思路来试图解决前端开发中的代码组织问题。

  2.MVC设计模式

  在提出本文提出的MCRV设计模式之前,有必要对其所基于的MVC设计模式进行阐述。

  MVC这个概念很早之前就被人提起[1],它代表一种设计思想。

MVC是Model-View-Conroller的缩写,即模型-视图-控制器。

这种开发模式将一个应用程序分为三个部分,模型(model)实现商业逻辑,提供数据;视图(view)负责向用户呈现界面和接受用户交互;控制器(controller)则负责响应用户交互请求,对用户请求进行翻译,根据不同的请求调用模型,执行商业逻辑。

控制器本质上是一个调度器(dispatcher),通过其包含的各个方法(action)来执行具体的商业逻辑。

MVC各个部件以最小的耦合性协同工作,从而使程序具有良好的可扩展性和可维护性和复用性。

  MVC设计模式最开始被用于桌面程序设计,典型地用于相同的数据需要不同的用户交互界面的设计场景。

在经典的MVC设计思想中,控制器负责响应用户事件,根据事件类型和参数调用模型或改变视图。

每个模型对应一个或者多个视图,当模型被控制器调用而得到改变时,模型向所有向其注册过的视图发送通知,视图根据从模型的中得到的信息改变外观。

这种设计模式可以用图1表示。

可以看出经典MVC设计模式中Controller、Model都可以改变视图。

图1经典MVC

  基于MVC模式的Web开发(后端)一般可以用图2表示。

在这种模式下,controller负责解析用户浏览器请求的URL,根据URL自动调用controller中的不同的Action响应用户请求。

Action调用model,然后将model返回的数据填充到view中,view被返回给用户浏览器。

Web服务端开发中典型的采用MVC模式的框架有CakePHP、Structs、Spring等等。

图2Server端Web开发中的MVC

  相对于早期的经典MVC模式,Web开发中的MVC模式存在一些变化,因为对于一个桌面应用程序而言,可以很方便地将视图注册给模型,当模型数据发生改变时,即时通知视图页面发生改变;而对于Web应用而言,即使将多个页面注册给一个模型,当模型发生变化时,模型无法主动发送消息给Web页面(因为Web应用都是基于请求/响应模式的),只有当用户请求浏览该页面时,控制器才负责调用模型数据来更新Web页面。

同时,Web开发中的MVC也比经典MVC具有更小的耦合性,因为Model不再与View发生交互,因此程序的结构更加良好,使Web前端开发和业务逻辑开发相分离变的简单。

  对于具有复杂交互逻辑和丰富界面的程序来说,MVC已被实践证明是一种行之有效的设计和开发思想。

采用MVC设计模式的系统具有较好的结构,较低的耦合性,代码具有很好的维护性,能够适应复杂的业务逻辑和视图展现变化。

它也非常适合团队开发,使开发人员分为不同的角色,专注于自己负责部分的开发。

  3.MCRV设计模式

  综上所述,MVC是解决具有复杂交互界面、代码规模大的应用程序面临代码组织、复用问题的有效设计模式。

基于此,本文尝试基于MVC设计思想解决前端开发中的类似问题。

  然而,在前端页面开发中不能直接套用MVC设计模式。

因为,前端开发中的Web页面包含了HTML、CSS、Javascript等多个种类的代码,相对Web后端来说,Web页面整体就是一个负责UI展现、用户本地交互、发送服务请求的大View,与经典MVC及Web后端开发MVC模式中的View皆有不同。

因此,需要具体问题具体分析。

  首先对Web页面中的HTML、CSS、Javascript等代码进一步分析,明确它们的具体功能分类。

根据业界提出的Web开发标准,Web页首先被分为了"内容-结构-表现-行为"几个部分。

内容、结构、表现是页面的静态部分,主要负责UI的展现,用户操作指令(键盘、鼠标)的接受,因此,内容、结构、表现属于视图(View)的范畴。

行为主要就是Javascript代码,负责对用户操作指令的响应。

在复杂ajax应用中,Javascript代码的功能一般包括:

响应用户指令,执行数据验证/处理、执行客户端交互逻辑,向服务器发送ajax请求,接受并处理服务器返回的数据,根据数据改变UI(向页面结构填充内容数据、变换样式等)。

基于模型-视图-控制器分离的思想,Javascript代码中的数据验证/处理、本地业务逻辑计算、向服务器发请求获取数据的功能,对应模型(Model)的功能;响应(翻译)用户操作指令,根据指令执行业务逻辑处理的功能,属于控制器(Controller)的功能;而接受处理过的数据,根据数据修改页面的内容/结构/样式的功能既不属于控制器的功范畴,也不属于模型的功能范畴,这部分代码因为根据数据对View进行呈现(render),可以命名为Renderer(渲染器或呈现器)。

  根据前述分析,本文提出了MCRV设计模式,如图3所示。

阐述如下:

图3:

MCRV开发模式

  M(Model):

模型,完成数据验证、数据处理,执行客户端业务逻辑计算,或向服务器发起ajax请求调用服务端逻辑、接受返回的数据,将处理后的数据返回控制器。

C(Controller):

控制器,控制器响应View上的事件,根据事件调度执行模型的业务逻辑,从业务逻辑获取返回数据,调度相应的渲染器(Render)来完成界面展现。

在这个过程中控制器会有数据的传递:

控制器调用模型中的逻辑时会传送Renderer搜集的数据(form表单各域的name/value、其他控制参数),模型执行逻辑后返回作为执行结果的数据给控制器,控制器根据数据来调用渲染器(renderer)来完成界面呈现(rendering),呈现(rendering)就是修改页面结构、内容和样式的过程。

数据传递过程可以用图4表示。

R(Renderer):

渲染器(呈现器),渲染器被控制器调用,接受从控制器传递的数据,完成对界面的具体渲染。

渲染器也负责控件(widget)的初始化,及建立Controller与具体事件的对应关系,事件发生时负责搜集View上的数据传送到Controller。

V(View):

视图,视图是用户最终看到的整个Web界面,由结构、内容、样式(表现)等静态内容共同构成;View由Renderer进行初始化渲染和修改。

 

图4:

数据传递过程

  可以看到在MCRV开发模式中,Controller处于控制中心的位置,Model完成具体的商业逻辑计算以及向后端发起ajax请求返回数据的功能。

Controller与Model、Renderer之间的交互本质上是数据交互的过程,它们之间存在着一个数据流,如图4所示。

因此,制定Controller、Model、Renderer之间的交互接口时,数据格式定义很重要。

  4.基于MCRV设计模式的Demo

  下面是一个用MCRV模式来开发的Demo页面,页面的功能是用表格展示和修改用户信息。

Javascript使用了jQuery库。

页面界面如图5所示。

页面代码在程序清单1中

图5:

基于MCRV设计模式的用户管理Demo

  程序清单1

DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http:

//www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

MCRV设计模式Demo

/********表现*********/

table{width:

100%;border-collapse:

collapse;}

td{border:

1pxsolidblack;padding:

2px;}

#container{width:

800px;margin:

0pxauto;}

#tbUsers{margin:

20pxauto;}

#tbUsersth{background-color:

navy;color:

white;text-align:

center;vertical-align:

middle;border:

1pxsolidnavy}

#tbUserstd{text-align:

center;}

.editCaption{width:

100px;text-align:

right;}

.buttonMargin{margin:

0px20px;}

.buttonContainer{text-align:

center;vertical-align:

middle;height:

50px}

-------结构--------->

id姓名年龄修改

none;"id="dvEditPanel">

id:

姓名:

年龄:

提交

取消

  5.基于MCRV模式的开发框架原型

  5.1基本设计思想

  框架是在一个特定的问题领域内,应用程序的部分设计与实现[2]。

框架与设计模式通常是精密结合的。

框架规定

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 总结汇报 > 其它

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1