当前位置: 首页 > news >正文

青岛seo网站管理app制作教学课程

青岛seo网站管理,app制作教学课程,齐齐哈尔铁峰建设局网站,提高网站速度以前学习MVVM模式时写了一篇《MVC、MVP和MVVM》。近来重读#xff0c;有了一些新想法。从MVC模式到MVVM模式的变化#xff0c;体现出在技术推动下#xff0c;界面构造方法从传统的过程式向声明式演进。从“在坐标(x,y)到(a,b)之间绘制一个红色矩形”到“坐标(x,y)到(a,b)之间…以前学习MVVM模式时写了一篇《MVC、MVP和MVVM》。近来重读有了一些新想法。从MVC模式到MVVM模式的变化体现出在技术推动下界面构造方法从传统的过程式向声明式演进。从“在坐标(x,y)到(a,b)之间绘制一个红色矩形”到“坐标(x,y)到(a,b)之间存在一个红色矩形”。 我们先简单了解一下从MVC到MVVM的演进过程。 图1  从MVC到MVVM的演进过程 从上图可以看出业务发展引发界面复杂度超出过程式构造方法适用范围为演进提供了驱动力和必要性。而数据绑定等自动化技术的突破为演进提供了路径和可行性。在两种要素的推动下MVC最终演进为MVVM。 1. MVC解耦业务逻辑/过程式渲染 在早期的应用中业务逻辑、界面渲染和用户交互代码常常混合在一起导致软件难以维护和进化。MVC通过引入一个中间层Controller对业务逻辑解耦解决了这个问题。MVC模型包含3个概念执行业务逻辑的Model、负责展示的View、处理用户输入协调Model和View的Controller。三者的静态结构和动态结构如下 图2  MVC模型静态结构 图3  MVC模型动态结构 代码1  MVC模型代码示例 class Controller {Model model;View view;void onClick() { UserInput userInput view.getUserInput();model.operate(userInput);Data newData model.getData();view.getTextView().setText(newData.getText());} }MVC完成了业务逻辑的解耦但界面渲染和用户交互的解耦并不彻底。Controller既处理用户输入又负责更新View。随着业务逻辑逐渐复杂Controller代码变得臃肿难以维护。Controller是一个重要的协调者但由于存在对View的依赖Controller难以进行测试。从渲染的角度来看渲染的过程是被动和过程式的。每次更新界面Controller向View发出绘制指令View根据指令绘制界面。这个过程中需要编写大量的代码绘制界面。 2. MVP解耦渲染指令/半声明式渲染 MVP进一步对界面渲染指令进行解耦同样的方法引入中间层。MVP包含3个主要概念Model、View和Presenter。看起来只是给Controller换了个名字实际上MVP完成了渲染指令的解耦。View不再暴露底层渲染指令而是提供高层级的更新界面方法。同时为了便于测试MVP将View提供的高层级的更新界面方法封装成接口构成了MVP中的一个隐含概念ViewInterface。Presenter不再依赖View而是采用面向接口编程原则让Presenter和View共同依赖于ViewInterface。 图4  MVP模型静态结构 图5  MVP模型动态结构 代码2  MVP模型代码示例 class Presenter {Model model;// Presenter不再直接依赖于View而是依赖于ViewInterface。ViewInterface viewInterface; void onClick() { UserInput userInput view.getUserInput();model.operate(userInput);Data newData model.getData();// Presenter不再直接执行底层绘制指令而是调用高层界面更新接口。viewInterface.update(newData);} } class View {View() {addClickListener(event - presenter.onClick())}}在MVC中驱动者Controller直接调用底层渲染指令。而在MVP中驱动者Presenter调用高层界面更新方法由View决定具体执行的底层渲染指令。MVP是由过程式向声明式转变的中间状态。 3. MVVM自动渲染/声明式渲染 MVP将渲染指令封装在View中将驱动者和渲染指令解耦。但这仍然是不彻底的仍然需要在View中编写大量的渲染代码。MVVM则更进一步利用数据绑定机制实现了声明式界面构建。驱动者ViewModel只需要声明预期的界面效果数据绑定机制完成由效果到渲染指令的转换实现自动渲染。在MVVM中已经不再需要手动编写渲染代码。 图6  MVVM模型静态结构 图7  MVVM模型动态结构 代码3  MVVM模型代码示例 class ViewModel {Model model;// 通过数据绑定直接获取用户输入。DataBind String userInput;ViewBind String outputText;void onClick() { model.operate(userInput);Data newData model.getData();// 通过数据绑定自动更新界面。outputText newData.getText();} } class View {View() {addClickListener(event - viewModel.onClick())}}4. 从过程式走向声明式 从MVC到MVVM体现了软件界面构造方法从过程式向声明式的演进过程。类似的演进在不同领域也曾发生过数据库查询语句也从命令式代码演进为声明式SQL。可见这是一条必经之路。当下一场更深刻的变更正在进行中软件开发活动自身正在从过程式人工编码向声明式AI代码生成演进。当然这篇文章存在很大的发布即过时的风险原因不在于过程式AI代码生成而是AI赋能让软件正在从功能容器向能力宿主转变传统的界面设计工具和方法无论是用户旅程图、MVC、MVP还是MVVM可能会快速失去使用场景。
http://www.hkea.cn/news/14540648/

相关文章:

  • 免费诶网站建设做网站的步骤
  • 国外客户推广网站北京 酒店 企业 网站建设
  • 网站建设基本流程包括哪几个重大军事新闻视频
  • .net网站开发程序员福建省住建厅网站官网
  • 东方财富网官方网站首页商贸公司起名字大全免费
  • 做空机构的网站seo怎么优化关键词排名培训
  • 网上做论文的网站有哪些内容搜索案例的网站
  • 校园网站建设情况说明书小程序开发需要服务器吗
  • 凡科建站官网采集wordpress整站数据
  • 瓯海住房与城乡建设局网站ui培训报名
  • 网站开发招标评分标准农产品网站建设方案
  • 京东联盟建网站阿里巴巴seo排名优化
  • 帮人家做家务的网站装置艺术那个网站做的好
  • 安阳网站优化建盏价格及图片及价格
  • 购物网站的英文湖南省新闻最新消息十条
  • 免费手机网站建站平台htnl5 做的视频网站
  • 网页就是一个网站的首页上海嘉定
  • 家居网站建设基本流程胶州企业网站设计
  • wordpress建两个网站成功案例展示网站
  • 绘制网站地图深圳app建设公司
  • 大学生怎么做网站服装市场调研报告范文
  • 苏州手机网站设计台州知名网站
  • 四川移动端网站建设网络服务器租用价格
  • 可以做翻译兼职的网站有哪些免费自己制作logo的网站
  • 建设企业网站公司简单大气静态网页模板
  • 网站黑链检测全屏网站源码
  • 大理市建设局网站百度智能建站平台
  • 建站费用参考宝山网站建设 网站外包
  • 杭州建设项目审批网站计算机网站设计怎么做
  • 网站建设排名的公司wordpress免费音乐主题