MVP框架

来源:互联网 发布:html点击按钮执行js 编辑:程序博客网 时间:2024/06/02 00:10

MVP的全称为Model-View-Presenter,Model提供数据,View负责显示,Controller/Presenter负责逻辑的处理。

MVP与MVC有着一个重大的区别:在MVP中View并不直接使用Model,它们之间的通信是通过Presenter (MVC中的Controller)来进行的,所有的交互都发生在Presenter内部,而在MVC中View会直接从Model中读取数据而不是通过 Controller。

1 简介

MVP 是从经典的模式MVC演变而来,它们的基本思想有相通的地方:Controller/Presenter负责逻辑的处理,Model提供数据,View负责显示。

作为一种新的模式,MVP与MVC有着一个重大的区别:在MVP中View并不直接使用Model,它们之间的通信是通过Presenter (MVC中的Controller)来进行的,所有的交互都发生在Presenter内部,而在MVC中View会从直接Model中读取数据而不是通过 Controller。

2 优缺点

2.1 优点

  1. 模型与视图完全分离,我们可以修改视图而不影响模型
  2. 可以更高效地使用模型,因为所有的交互都发生在一个地方——Presenter内部
  3. 我们可以将一个Presenter用于多个视图,而不需要改变Presenter的逻辑。这个特性非常的有用,因为视图的变化总是比模型的变化频繁。
  4. 如果我们把逻辑放在Presenter中,那么我们就可以脱离用户接口来测试这些逻辑(单元测试)

2.2 缺点

  1. 由于对视图的渲染放在了Presenter中,所以视图和Presenter的交互会过于频繁。
  2. 如果Presenter过多地渲染了视图,往往会使得它与特定的视图的联系过于紧密。一旦视图需要变更,那么Presenter也需要变更了。

3 MVP结构图

4 架构实现。

相关搭建项目环节就不介绍了,直接显示最核心的过程。

4.1 Model层

Model层和MVC框架的模型层使用同样的代码结构。

////  YJModel.swift//  MVP////  CSDN:http://blog.csdn.net/y550918116j//  GitHub:https://github.com/937447974/Blog////  Created by yangjun on 15/11/28.//  Copyright © 2015年 阳君. All rights reserved.//import Foundation/// 模型层的协议protocol YJModelProtocol {    func execute(model: YJModel)}/// model层,处理与服务器的响应class YJModel: NSObject {    /// 相关数据,发送到服务器的数据以及从服务器接收的数据    var data: Dictionary<String, AnyObject>?    /// 回调代理    var delegate: YJModelProtocol?    /// 向服务器发送数据    ///    /// - returns: void    func sendRequest() {        print("\nModel Begin============")        print("Model收到通知开始请求服务器")        print("服务器接收数据:\(self.data)")        if self.data == nil {            self.data = Dictionary()        }        self.data!["qq"] = "937447974"        print("服务器数据处理完毕,回发中...")        print("Model收到服务器发回的数据,通知Presenter层")        print("Model End============")        self.delegate?.execute(self)    }}

定义了一个模型类Model以及网络回调协议ModelProtocol。当外部调用类遵循这种协议时即可回调数据。

4.2 Presenter层

Presenter与具体的View是没有直接关联的,而是通过定义好的接口进行交互,从而使得在变更View时候可以保持Presenter的不变,即重用。

////  YJPresenter.swift//  MVP////  CSDN:http://blog.csdn.net/y550918116j//  GitHub:https://github.com/937447974/Blog////  Created by yangjun on 15/11/28.//  Copyright © 2015年 阳君. All rights reserved.//import Foundation/// Presenter层的协议,view层实现protocol YJPresenterProtocol {    // 定义一系列通知UI的接口    func execute(presenter: YJPresenter)}/// Presenter完全把Model和View进行了分离,主要的程序逻辑在Presenter里实现。class YJPresenter: YJModelProtocol {    /// 姓名    var name: String?    /// view层代理    var delegate: YJPresenterProtocol?    // 开始数据准备    func initData() {        print("\nPresenter Begin++++++++++++")        print("Presenter层收到UI指令")        // 向服务器发送数据        let model = YJModel()        model.data = Dictionary()        model.data!["name"] = "阳君"        model.delegate = self // 当前类接收数据        print("开始请求Model层获取数据")        model.sendRequest()    }    func execute(model: YJModel) {        print("\nPresenter层收到Model层数据:\(model.data)")        self.name = model.data?["name"] as? String        print("Presenter层通知UI层,数据已准备")        print("Presenter End++++++++++++")        self.delegate?.execute(self)    }}

在Presenter层定义了YJPresenterProtocol协议,这是Presenter和View层沟通的通道。在Presenter层我们实现了和Model层的交互,这样就解放了View层的代码量。

4.3 View层

View层就是ViewController了,这里的ViewController只控制UI界面的交互,至于和服务器之间的交互交给Presenter层。

////  YJViewController.swift//  MVP////  CSDN:http://blog.csdn.net/y550918116j//  GitHub:https://github.com/937447974/Blog////  Created by yangjun on 15/11/28.//  Copyright © 2015年 阳君. All rights reserved.//import UIKit/// View层class YJViewController: UIViewController, YJPresenterProtocol {    /// 姓名    @IBOutlet weak var name: UILabel!    /// Presenter层    var persenter = YJPresenter()    override func viewDidLoad() {        super.viewDidLoad()        print("View Begin------------")        self.persenter.delegate = self        print("View层发出指令通知Presenter层")        self.persenter.initData()// 初始化数据    }    // MARK: - YJPresenterProtocol    func execute(presenter: YJPresenter) {        print("\nView层收到Presenter层通知")        self.name.text = presenter.name        print("View End------------")    }}

这里定义了一个name: UILabel属性,指向界面中的元素,这样能让我们直观的感受到,从UI到服务器直接交互的整个流程。

4.4 测试

运行项目后可看见如下输出效果,会发现层与层之间的关系非常清晰,代码的可维护度非常高。

View Begin------------View层发出指令通知Presenter层Presenter Begin++++++++++++Presenter层收到UI指令开始请求Model层获取数据Model Begin============Model收到通知开始请求服务器服务器接收数据:Optional(["name": 阳君])服务器数据处理完毕,回发中...Model收到服务器发回的数据,通知Presenter层Model End============Presenter层收到Model层数据:Optional(["qq": 937447974, "name": 阳君])Presenter层通知UI层,数据已准备Presenter End++++++++++++View层收到Presenter层通知View End------------

 


其他

源代码

Framework

参考资料

MVP

文档修改记录

时间 描述 2015-11-28 博文完成

版权所有

CSDN:http://blog.csdn.net/y550918116j

GitHub:https://github.com/937447974/Blog

0 0
原创粉丝点击