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


推荐阅读
  • 本文讨论了在ASP中创建RazorFunctions.cshtml文件时出现的问题,即ASP.global_asax不存在于命名空间ASP中。文章提供了解决该问题的代码示例,并详细解释了代码中涉及的关键概念,如HttpContext、Request和RouteData等。通过阅读本文,读者可以了解如何解决该问题并理解相关的ASP概念。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • position属性absolute与relative的区别和用法详解
    本文详细解读了CSS中的position属性absolute和relative的区别和用法。通过解释绝对定位和相对定位的含义,以及配合TOP、RIGHT、BOTTOM、LEFT进行定位的方式,说明了它们的特性和能够实现的效果。同时指出了在网页居中时使用Absolute可能会出错的原因,即以浏览器左上角为原始点进行定位,不会随着分辨率的变化而变化位置。最后总结了一些使用这两个属性的技巧。 ... [详细]
  • Python开源库和第三方包的常用框架及库
    本文介绍了Python开源库和第三方包中常用的框架和库,包括Django、CubicWeb等。同时还整理了GitHub中最受欢迎的15个Python开源框架,涵盖了事件I/O、OLAP、Web开发、高性能网络通信、测试和爬虫等领域。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • Asp.net Mvc Framework 七 (Filter及其执行顺序) 的应用示例
    本文介绍了在Asp.net Mvc中应用Filter功能进行登录判断、用户权限控制、输出缓存、防盗链、防蜘蛛、本地化设置等操作的示例,并解释了Filter的执行顺序。通过示例代码,详细说明了如何使用Filter来实现这些功能。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了使用postman进行接口测试的方法,以测试用户管理模块为例。首先需要下载并安装postman,然后创建基本的请求并填写用户名密码进行登录测试。接下来可以进行用户查询和新增的测试。在新增时,可以进行异常测试,包括用户名超长和输入特殊字符的情况。通过测试发现后台没有对参数长度和特殊字符进行检查和过滤。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
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社区 版权所有