欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    JavaScript的MVC模式.docx

    • 资源ID:69684473       资源大小:28.62KB        全文页数:6页
    • 资源格式: DOCX        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    JavaScript的MVC模式.docx

    呼叫中心专家 JavaScript的MVC模式我喜欢 JavaScript,因为它是在世界上最灵活的语言之一。在 JavaScript 中,程序员可以根据自己的口味选择编程风格:面向过程或面向对象。如果你是一个重口味,JavaScript 一样可以应付自如:面向过程,面向对象,面向方面,使用 JavaScript 开发人员甚至可以使用函数式编程技术。这篇文章中,我的目标是编写一个简单的 JavaScript 组件,来向大家展示一下 JavaScript 的强大。该组件是一个可编辑的项目列表(HTML中的 select 标签):用户可以选择某一项并删除它,或者添加新的项目到列表中。组件将由三个类构成,分别对应着 MVC 设计模式的模型-视图-控制器。这篇文章只是一个简单的指导。如果你希望在实际的项目中使用它,你需要进行适当的修改。我相信你拥有创建和运行 JavaScript 程序的一切:大脑,双手,文本编辑器(如记事本),浏览器(例如我的最爱 Chrome)。既然我们的代码要使用 MVC 模式,因此我在这里简单介绍一个这个设计模式。 MVC 模式的英文名称是 Model-View-Controller pattern,顾名思义,其主要部分组成:模型Model(),用于存储程序中使用到的数据;视图(View),用不同的表现形式来呈现数据;控制器(Controller),更新模型。在维基百科对 MVC 体系结构的定义中,它由如下三部分组成:模型(Model) -“数据模型”(Model)用于封装与应用程序的业务逻辑相关的数据以及对数据的处理方法。 “模型”有对数据直接访问的权力。 “模型”不依赖“视图”和“控制器”,也就是说,模型不关心它会被如何显示或是如何被操作。视图(View) - 视图层能够实现数据有目的的显示,通常是一个用户界面元素。在视图中一般没有程序上的逻辑。在 Web 应用程序中的 MVC,通常把显示动态数据的 html 页面称为视图。控制器(Controller) - 处理和响应事件,通常是用户操作,并监控模型上的变化,然后去修改视图。The data of the component is a list of items, in which one particular item can be selected and deleted. So, the model of the component is very simple - it is stored in an array property and selected item property; and here it is:我们将基于 MVC 实现一个数据列表组件,列表中的项目可以被选择和删除。因此,组件模型是非常简单的 - 它只需要两个属性:数组 _items 用来存储所有元素;普通变量 _selectedIndex 用来存储选定的元素索引代码如下:1. /*  2.  * 模型。  3.  *  4.  * 模型存储所有元素,并在状态变更时通知观察者(Observer)。  5.  */   6. function ListModel(items)   7.     this._items = items;        / 所有元素  8.     this._selectedIndex = -1;   / 被选择元素的索引  9.  10.     this.itemAdded = new Event(this);  11.     this.itemRemoved = new Event(this);  12.     this.selectedIndexChanged = new Event(this);  13.  14.  15. ListModel.prototype =   16.     getItems : function ()   17.         return .concat(this._items);  18.     ,  19.  20.     addItem : function (item)   21.         this._items.push(item);  22.         this.itemAdded.notify(item : item);  23.     ,  24.  25.     removeItemAt : function (index)   26.         var item;  27.  28.         item = this._itemsindex;  29.         this._items.splice(index, 1);  30.         this.itemRemoved.notify(item : item);  31.  32.         if (index = this._selectedIndex)   33.             this.setSelectedIndex(-1);  34.           35.     ,  36.  37.     getSelectedIndex : function ()   38.         return this._selectedIndex;  39.     ,  40.  41.     setSelectedIndex : function (index)   42.         var previousIndex;  43.  44.         previousIndex = this._selectedIndex;  45.         this._selectedIndex = index;  46.         this.selectedIndexChanged.notify(previous : previousIndex);  47.       48. ;  Event 是一个简单的实现了观察者模式(Observer pattern)的类:1. function Event(sender)   2.     this._sender = sender;  3.     this._listeners =   4.  5.  6. Event.prototype =   7.     attach : function (listener)   8.         this._listeners.push(listener);  9.     ,  10.  11.     notify : function (args)   12.         var index;  13.  14.         for (index = 0; index < this._listeners.length; index += 1)   15.             this._listenersindex(this._sender, args);  16.           17.       18. ;  View 类需要定义控制器类,以便与它交互。虽然这个任务可以有许多不同的接口(interface),但我更喜欢最简单的。我希望我的项目是在一个 ListBox 控件和它下面的两个按钮:“加号”按钮添加项目,“减”删除所选项目。组件所提供的“选择”功能则需要 select 控件的原生功能的支持。一个 View 类被绑定在一个 Controller 类上,其中控制器处理用户输入事件,通常是通过一个已注册的回调函数(wikipedia.org)。下面是 View 和 Controller 类:1. /*  2.  * 视图。  3.  *   4.  * 视图显示模型数据,并触发 UI 事件。  5.  * 控制器用来处理这些用户交互事件  6.  */   7. function ListView(model, elements)   8.     this._model = model;  9.     this._elements = elements;  10.  11.     this.listModified = new Event(this);  12.     this.addButtonClicked = new Event(this);  13.     this.delButtonClicked = new Event(this);  14.  15.     var _this = this;  16.  17.     / 绑定模型监听器  18.     this._model.itemAdded.attach(function ()   19.         _this.rebuildList();  20.     );  21.  22.     this._model.itemRemoved.attach(function ()   23.         _this.rebuildList();  24.     );  25.  26.     / 将监听器绑定到 HTML 控件上  27.     this._elements.list.change(function (e)   28.         _this.listModified.notify( index : e.target.selectedIndex );  29.     );  30.  31.     this._elements.addButton.click(function ()   32.         _this.addButtonClicked.notify();  33.     );  34.  35.     this._elements.delButton.click(function ()   36.         _this.delButtonClicked.notify();  37.     );  38.  39.  40. ListView.prototype =   41.     show : function ()   42.         this.rebuildList();  43.     ,  44.  45.     rebuildList : function ()   46.         var list, items, key;  47.  48.         list = this._elements.list;  49.         list.html('');  50.  51.         items = this._model.getItems();  52.         for (key in items)   53.             if (items.hasOwnProperty(key)   54.                 list.append($('<option>' + itemskey + '</option>');  55.               56.           57.  58.         this._model.setSelectedIndex(-1);  59.       60. ;  61.  62. /*  63.  * 控制器。  64.  *  65.  * 控制器响应用户操作,调用模型上的变化函数。  66.  */   67. function ListController(model, view)   68.     this._model = model;  69.     this._view = view;  70.  71.     var _this = this;  72.  73.     this._view.listModified.attach(function (sender, args)   74.         _this.updateSelected(args.index);  75.     );  76.  77.     this._view.addButtonClicked.attach(function ()   78.         _this.addItem();  79.     );  80.  81.     this._view.delButtonClicked.attach(function ()   82.         _this.delItem();  83.     );  84.  85.  86. ListController.prototype =   87.     addItem : function ()   88.         var item = window.prompt('Add item:', '');  89.         if (item)   90.             this._model.addItem(item);  91.           92.     ,  93.  94.     delItem : function ()   95.         var index;  96.  97.         index = this._model.getSelectedIndex();  98.         if (index != -1)   99.             this._model.removeItemAt(this._model.getSelectedIndex();  100.           101.     ,  102.  103.     updateSelected : function (index)   104.         this._model.setSelectedIndex(index);  105.       106. ;  当然,Model, View, Controller 类应当被实例化。下面是一个使用此 MVC 的完整代码:1. $(function ()   2.     var model = new ListModel('PHP', 'JavaScript'),  3.  4.     view = new ListView(model,   5.         'list' : $('#list'),   6.         'addButton' : $('#plusBtn'),   7.         'delButton' : $('#minusBtn')  8.     ),  9.  10.     controller = new ListController(model, view);          11.     view.show();  12. );  13.  14. <select id="list" size="10" style="width: 15em"></select><br/>  15. <button id="plusBtn">  +  </button>  16. <button id="minusBtn">  -  </button>  本文由 整理分享

    注意事项

    本文(JavaScript的MVC模式.docx)为本站会员(asd****56)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开