热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

html完整框架,wpfmvvm框架

在MVC设计中,View是唯一与用户交互的地方,或者说它是Model变化后的直观反映。在MVVM中,View被认为是主动的而非被动的。而MVVM中View是具有主动性的,因为它包括


MVM(ModelviewViewModel )是基于MVC的设计,开发人员在HTML中写入了一些绑定,只要利用一些指令绑定,就可以在保持model和viewmodel不变的情况下,实现UI设计和业务逻辑


起源


MVM这个概念是2005年微软工程师John Grossman在博客中提出的,最初在微软的WPF中使用。 直到最近几年,MVVM这个设计才通过Javascript实现,产生了许多框架,包括KnockoutJS、Kendo MVVM和Knockback.js。 这些框架的社区非常活跃。


什么是MVVM


模特


作为MV*家族的一员,MVVM的m代表模型。 模型表示我们整个webapp所需的数据模型。 典型的例子是用户信息Model,它必须包含(名称、年龄等属性)。 模型包含许多信息,但没有行为逻辑,只有数据,因此不影响浏览器显示数据的方式。


视图


我认为View这个词出现频率最高的是MVC。 在MVC设计中,View是唯一与用户交互的地方,或者是模型改变后的直观反映。 在MVVM中,View被视为主动而不是被动。 对于被动的View,它只能被“他人”(Controller )摆布,自己无法改变任何事情,比如使用Jquery操作DOM。 在MVVM中,View是主动的。 因为它包含了直接影响模型和ViewModel的数据绑定、事件和行为。 这不仅可以保持View自身的行为(展示),还可以使自身的变化与ViewModel同步。


视图模型


ViewModel可视为MVC的控制器,主要负责数转换,运用一定的业务逻辑,将模型的变化反映到View中,在View自身有变化的情况下也同步进行模型的变化。 ViewModel暴露了View所需的数据,可以认为是隐藏在View后面的好帮手,富有View一定的行动能力。 说这么多,我们先来看看knockoutjs的Demo:吧


html


first name :http://www.Sina.com /


last name :http://www.Sina.com /


Javascript


//thisisasimple * viewmodel *-Javascriptthatdefinesthedataandbehaviorofyourui


函数应用程序视图模型(


this.firstName='Bert ';


this.lastName='Bertington ';


}


//Activates knockout.js


ko.apply bindings (new app viewmodel ) );


页面效果:


First name: Bert


Last name: Bertington


ViewModel将文本命令绑定到View,并告知相应的tag可以利用ViewModel中的数据渲染DOM。 这只是ViewModel到View的单个绑定。 双向绑定需要observable对象。 稍后再解释。


好处


1.UI和逻辑的分离。


写unit测试很方便,但测量ViewModel比测量Event方便多了。


缺点


如果为Bindings编写了自定义方法,则在正好需要调试的时候,此方法可能会有点不方便。


2 .对于交互较少的webapp,MVVM稍重


3 .对于大型webapp,所有逻辑和数据都位于ViewModel中,ViewModel变得越来越复杂。


其实MVVM的缺点还有很多,但都是特定场合的特定问题。 但是,我个人认为其优点是上述两大方面。 虽然它也有很多不足和缺点,但是zydxy的webapp是中小型的,在有复杂的交互时,如果你还在Jquery上操作DOM,我建议你马上更换框架。


从使用MVVM一段时间的经验来看,我个人认为在特定的场合它确实很出色,所以我决定自己研究一下MVVM的实现原理。 基于knockoutjs,构建与其接口相同的MVVM框架(某些主要接口)。 我不要求有多优秀,而是想出手实现。 实现MVVM后,在之后的博客中介绍MVVM的模板引擎和模板引擎,请参考原文


推荐阅读
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • Struts与Spring框架的集成指南
    本文详细介绍了如何将Struts和Spring两个流行的Java Web开发框架进行整合,涵盖从环境配置到代码实现的具体步骤。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文深入探讨了C++对象模型中的一些细节问题,特别是虚拟继承和析构函数的处理。通过具体代码示例和详细分析,揭示了书中某些观点的不足之处,并提供了更合理的解释。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
author-avatar
湛蓝天空jk
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有