MVP架構

来源:http://www.cnblogs.com/zhangmiao14/archive/2017/06/27/7087097.html
-Advertisement-
Play Games

一、介紹 MVP(Model View Presenter)架構是從著名的MVC(Model View Controller)架構演變而來的。對於在Android應用中開發就可以視為是MVC架構,佈局文件視為View,Activity視為Controller,但是Activity還要控制佈局的更新, ...


一、介紹

  MVP(Model View Presenter)架構是從著名的MVC(Model View Controller)架構演變而來的。對於在Android應用中開發就可以視為是MVC架構,佈局文件視為View,Activity視為Controller,但是Activity還要控制佈局的更新,所以說Activity是Controller與View的合體,這樣的結果是Actiivty的代碼很多也很雜亂,而MVP就是將Activity充當的Controller與View的角色分割開來。
  View:對於View層也是視圖層,在View層中只負責對數據的展示,提供友好的界面與用戶進行交互。在Android開發中通常將Activity或者Fragment作為View層。
  Model:對於Model層也是數據層。它區別於MVC中的Model,在這裡不僅僅只是數據模型。在MVP架構中Model它負責對數據的存取操作,例如對數據的讀取,網路的數據請求等。
  Presenter:對於Presenter層也是連接View層與Model層的橋梁並對業務邏輯進行處理。在MVP架構中Model與View無法直接進行交互。所以在Presenter層它會從Model層獲得所需要的數據,進行一些適當的處理後交由View層進行顯示,這樣通過Presenter將View與Model進行隔離,使得View和Model之間不存在耦合,同事也將業務邏輯從View中抽離。

  在MVP架構中將這三層分別抽象到各自的介面當中。通過介面將層次之間進行隔離,而Presenter對View和Model的相互依賴也是依賴於各自的介面。這點符合了介面隔離原則,也正是面向介面編程。在Presenter層中包含了一個View介面,並且依賴於Model介面,從而將Model層與View層聯繫在一起。而對於View層會持有一個Presnter成員變數並且只保留對Presenter介面的調用,具體業務邏輯全部交由Presnter介面實現類中處理。

二、好處

  1.View與Model並不直接進行交互,而是通過Presenter連接彼此。View中不存在Model,從而也不會存在業務邏輯。
  2.Presenter與View的互動式通過介面來實現的,耦合度低,也有利於單元測試。
  3.Presenter是基於行為的,一個Presnter可用於多個View,增強了代碼復用。

三、使用

  使用MVP架構來實現一個ListView的顯示。
  1.定義一個Mode介面

public interface IMode {
    List<String> getDatas();
}

  2.定義一個IView介面

public interface IView {

    void showProgress();

    void hideProgress();

    void showText(String text);

    void showDatas(List<String> datas);

    void showToast(String message);

}

  3.定義一個Presenter介面

public interface IPresenter {

    void getDataList();

    void onItemClick(int position);
}

  4.定義MainMode類實現IMode介面

public class MainMode implements IMode {
    @Override
    public List<String> getDatas() {
        List<String> datas = new ArrayList<>();
        //return datas;
        datas.add("A");
        datas.add("B");
        datas.add("C");
        datas.add("D");
        datas.add("E");
        datas.add("F");
        return datas;
        //return null;
    }
}

  5.定義MainPresenter類實現IPresenter介面

public class MainPresenter implements IPresenter {

    private IView mView;
    private IMode mMode;

    public MainPresenter(IView mView) {
        this.mView = mView;
        mMode = new MainMode();
    }

    @Override
    public void getDataList() {
        mView.showProgress();
        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                List<String> datas = mMode.getDatas();
                mView.hideProgress();
                if (datas == null) {//獲取數據失敗
                    mView.showText("請求數據失敗!");
                } else {//獲取數據成功
                    if (datas.size() == 0) { //數據為空
                        mView.showText("數據為空!");
                    } else {
                        mView.showDatas(datas);
                    }
                }
            }
        }, 2000);
    }

    @Override
    public void onItemClick(int position) {
        mView.showToast(String.format("Position %d clicked", position + 1));
    }
}

  6.定義MainActivity類實現IView介面

public class MainActivity extends AppCompatActivity implements IView, AdapterView.OnItemClickListener {

    private ListView mListView;
    private ProgressBar mProgressBar;
    private TextView mTextView;

    private IPresenter mPresenter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mListView = (ListView) findViewById(R.id.list);
        mProgressBar = (ProgressBar) findViewById(R.id.progress);
        mTextView = (TextView) findViewById(R.id.text);
        mPresenter = new MainPresenter(this);
        mPresenter.getDataList();
    }

    @Override
    public void showProgress() {
        mProgressBar.setVisibility(View.VISIBLE);
        mListView.setVisibility(View.GONE);
    }

    @Override
    public void hideProgress() {
        mProgressBar.setVisibility(View.GONE);
        mListView.setVisibility(View.VISIBLE);
    }

    @Override
    public void showText(String text) {
        mProgressBar.setVisibility(View.GONE);
        mListView.setVisibility(View.GONE);
        mTextView.setVisibility(View.VISIBLE);
        mTextView.setText(text);
    }

    @Override
    public void showDatas(List<String> datas) {
        mListView.setAdapter(new ArrayAdapter<>(this, R.layout.simple_list_item, datas));
    }

    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        mPresenter.onItemClick(position);
    }

    @Override
    public void showToast(String message) {
        Toast.makeText(this, message, Toast.LENGTH_SHORT).show();
    }
}


代碼地址:https://github.com/ZhangMiao147/FrameworkDemo

 

參考文章
  http://www.lai18.com/content/7010875.html
  http://www.lai18.com/content/2453405.html
  http://www.lai18.com/content/475341.html
  http://www.lai18.com/content/24630178.html
  http://www.lai18.com/content/719388.html
  http://www.lai18.com/content/7017296.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 原型鏈繼承 Child.prototype = new Parent(); 2. call(thisObj, param1, param2,...) 3. apply(thisObj, [param1,param2,...]) 4. 組合繼承(call+原型鏈 / apply+原型鏈) 5.寄 ...
  • [1]引入 [2]display [3]顯式網格 [4]間距 [5]網格線 [6]網格線命名 [7]網格區域命名 [8]隱式網格 [9]隱式命名 [10]網格項目層級 [11]對齊 ...
  • 圓形 circle 矩形 rect 橢圓 ellipse 線 line 折線 polyline 多邊形 polygon 路徑 path 可用於路徑數據的命令 M = moveto L = lineto H = horizontal lineto V = vertical lineto C = cur ...
  • 1.SVG 是用XML格式定義的矢量圖。 2.文件體積小,能夠被大量的壓縮。 3.圖片可無限放大而不失真(矢量圖的基本特征)。 4.在視網膜顯示屏上效果極佳。 5.能夠實現互動和濾鏡效果。 6.svg元素里提供了“width”和“height”兩個屬性來定義SVG圖片的高度和寬度。 7.fill屬性 ...
  • 此文章是稍早前寫的,本次屬於文章遷移@2017.06.27 前言 俗話說“在js語言中,一切都對象”,而且創建對象的方式也有很多種,所以今天我們做一下梳理 最簡單的方式 JavaScript創建對象最簡單的方式是:對象字面量形式或使用Object構造函數 對象字面量形式 使用Object構造函數 明 ...
  • /^(0(?:[.](?:[1-9]\d?|0[1-9]))|[1-9]\d*(?:[.]\d{1,2}|$))$/ 不為0的正整數或帶1到2位小數的數字(以0打頭的則後面必須接小數點且小數點後面必然為01-99,以大於0的數打頭則小數可為1至2位任意數字或無小數部分.) ...
  • 1.設置佈局屬性: 2.BitmapUtils類-- 得到指定圓形的Bitmap對象 3.BitmapUtils類--壓縮圖片 4.根據user.getImageurl()顯示圓形圖像 ...
  • 轉自:http://www.cnblogs.com/daiweilai/p/4421340.html 侵刪 目錄 前言逼優雞知己知彼 百戰不殆抽刀斷Bug 普通操作 全局斷點(Global BreakPoint) 條件斷點(Condational Breakpoints)列印的藝術 NSLog 開啟 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...