IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> Android与Vue架构分析,MVC、MVP、MVVM的演进 -> 正文阅读

[开发测试]Android与Vue架构分析,MVC、MVP、MVVM的演进

  • MVC

? ?

  • ?普通Html演示MVC思想,视图-->Controller--->Model
<!DOCTYPE html>
<html>
<body>
<!--视图部分View-->
<input value="张三" >

<button onclick="controlClick()">获取input<->model</button>

<script>
model = {};

// controller 
function controlClick()
{
  myInput = document.getElementsByTagName("INPUT")[0];
  // 获取数据 绑定到模型 
  model['name']=myInput.value
  clickService(model)
}

function controlSetInputValue(newvalue){
  myInput = document.getElementsByTagName("INPUT")[0];
  myInput.value = newvalue
}

// 业务逻辑层model
function clickService(model){
  // 业务逻辑处理处理,例如存储数据库、发送网络请求等
  if(model['name'] == '张三'){
    newname = '李四'
  }else{
    newname = '王五'
  }
  controlSetInputValue(newname)
  
}

</script>

</body>
</html>

分析:

1.MVC核心就是和视图和数据业务层隔离解除耦合,增强了可维护性,职责分明

2.但是实际过程中控制层和视图层耦合比较重,且需要大量的重新性UI操作代码

3.同时Android中Activity也有类似问题,一方面需要监听视图的变化、一方面网络请求、一方面又要更新UI,十分繁琐

4.MVP思想则是将视图层和model层切断,主要通过在P层抽象化UI操作的方式实现,但是也需要大量的UI和数据组合操作

  • MVVM解决方案

? ??

?普通Html演示MVVM思想

<!DOCTYPE html>
<html>
<body>
<!--视图部分View-->
<input value="XXX" >

<button onclick="requestNet()">请求网络</button>

<script>
var viewmodel = {};
var value="";

Object.defineProperty(viewmodel,"name",{
    //获取值getter
    get(){
      myInput = document.getElementsByTagName("INPUT")[0];
      if(!value){
      	return myInput.value
      }
      return value
    },
    //监听数据发生变化设置值,setter
    set(val){
      myInput = document.getElementsByTagName("INPUT")[0];
      value = val
      myInput.value = val
      
    }
  })

function requestNet(){
	// 通过viewmodel获取控件的值
	alert(viewmodel.name)
    // 通过viewmodel设置控件的值
    viewmodel.name="李四";
}


</script>

</body>
</html>

1.MVVM的思想则是自动的将model层的结果映射到view上,不需要频繁直接更新UI,而model层获取view的信息也不需要直接操作UI

2.MVVM核心原理就是双向绑定,其结果可以到达UI层可以自动响应数据的变化,也就是响应式

3.MVVM最大特点就是屏蔽了复杂的频繁操作,再通过一些Diff对比等,减少UI操作,提高性能

4.MVVM因为需要ViewModel层监听数据变化和UI更新,相互映射,也提高了底层的复杂性

参考资料:

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-07-05 20:28:17  更:2021-07-05 20:28:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/2 8:57:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码