热门标签 | 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的模板引擎和模板引擎,请参考原文


推荐阅读
  • ABP框架是ASP.NET Boilerplate的简称,它不仅是一个开源且文档丰富的应用程序框架,还提供了一套基于领域驱动设计(DDD)的最佳实践架构模型。本文将详细介绍ABP框架的特点、项目结构及其在Web API优先架构中的应用。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • 在运行于MS SQL Server 2005的.NET 2.0 Web应用中,我偶尔会遇到令人头疼的SQL死锁问题。过去,我们主要通过调整查询来解决这些问题,但这既耗时又不可靠。我希望能找到一种确定性的查询模式,确保从设计上彻底避免SQL死锁。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 对象存储与块存储、文件存储等对比
    看到一篇文档,讲对象存储,好奇,搜索文章,摘抄,学习记录!背景:传统存储在面对海量非结构化数据时,在存储、分享与容灾上面临很大的挑战,主要表现在以下几个方面:传统存储并非为非结 ... [详细]
  • 告别jQuery:Bootstrap5即将全面脱离jQuery依赖及其他前端热点
    本文精选了2019年2月「前端大全」平台上的15篇热门文章,涵盖技术分享与资源推荐。关注前端大全,获取更多前沿信息,提升您的前端技能。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • MVC模式下的电子取证技术初探
    本文探讨了在MVC(模型-视图-控制器)架构下进行电子取证的技术方法,通过实际案例分析,提供了详细的取证步骤和技术要点。 ... [详细]
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • 深入解析Unity3D游戏开发中的音频播放技术
    在游戏开发中,音频播放是提升玩家沉浸感的关键因素之一。本文将探讨如何在Unity3D中高效地管理和播放不同类型的游戏音频,包括背景音乐和效果音效,并介绍实现这些功能的具体步骤。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 本文介绍如何使用JavaScript中的for循环来创建一个九九乘法表,适合初学者学习循环结构的应用。 ... [详细]
  • 本文详细记录了 MIT 6.824 课程中 MapReduce 实验的开发过程,包括环境搭建、实验步骤和具体实现方法。 ... [详细]
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社区 版权所有