MVC,MVP的問題,透過圖書和論文來找解法和答案更準確安心。 我們找到下列懶人包和總整理

MVC,MVP的問題,我們搜遍了碩博士論文和台灣出版的書籍,推薦李雲鵬寫的 移動開發架構設計實戰 和Osmani, Addy的 Learning JavaScript Design Patterns都 可以從中找到所需的評價。

這兩本書分別來自電子工業 和所出版 。

國立中央大學 數學系 吳維漢所指導 吳均熠的 子由數學小學堂 Android App 開發:操作介面設計 (2020),提出MVC,MVP關鍵因素是什麼,來自於子、由、子由數學。

而第二篇論文國立臺北科技大學 機械工程系機電整合碩士班 黃榮堂、韓麗龍所指導 李如昀的 基於物聯網的多手機應用程式端之智慧系統的開發與資料整合 (2019),提出因為有 智慧消防、智慧停車、物聯網、乳酸測量、飲食紀錄、整合開發的重點而找出了 MVC,MVP的解答。

接下來讓我們看這些論文和書籍都說些什麼吧:

除了MVC,MVP,大家也想知道這些:

移動開發架構設計實戰

為了解決MVC,MVP的問題,作者李雲鵬 這樣論述:

本書覆蓋了移動開發中涉及的多種架構模式,基於Android平臺對架構模式進行實戰,可以説明入門開發者瞭解架構模式,進階開發者掌握架構模式,技術領導者進行架構選型。本書內容包括:流行架構模型MVX系列——MVC架構、MVP架構、MVVM架構,依賴注入框架Dagger2,函數回應式框架RxJava2,Google推薦的生命週期感知架構組件AAC,整潔的架構“The Clean Architecture”和元件化架構的運用方法與實戰。本書語言精練,內容清晰,代碼易於理解,適合電腦相關行業的從業者閱讀與學習。 李雲鵬 網易新聞架構技術組工程師,沐暄網創始人,Oracle、Adob

e等企業認證專家;10年互聯網經驗,曾就職于世界500強企業核心技術實驗室;于2009年創立沐暄網,2010年入圍鳳凰網“全球最具影響力的中文論壇100強”站長。 擅長移動端架構設計、專案重構與Intellij外掛程式開發等工作。參與網易新聞群組件化架構設計,視頻模組、統計模組等多模組重構工作,利用VIPER對用戶端基礎架構進行改良。喜歡創新和研究,作為第一發明人,申請了十余項專利和著作權。   第1章 什麼是架構 1 1.1 架構設計理念 1 1.1.1 軟體架構的起源 1 1.1.2 架構設計三要素 2 1.1.3 什麼是優秀的軟體架構設計 2 1.1.4 軟體架構設

計的關注點 3 1.2 軟體架構設計的本質和目的 3 1.2.1 做出決策 3 1.2.2 降低軟體熵 4 1.3 架構設計思維 4 1.3.1 簡化思維 4 1.3.2 分層思維 5 1.3.3 分治思維 6 1.3.4 反覆運算思維 6 1.4 架構設計模式原則 7 1.4.1 單一職責原則 7 1.4.2 開放封閉原則 8 1.4.3 裡氏替換原則 9 1.4.4 依賴倒置原則 9 1.4.5 介面分離原則 10 1.5 架構設計步驟 11 1.5.1 認識系統 11 1.5.2 設計系統 12 1.5.3 創建系統 14 1.5.4 收集回饋 14 1.6 小結 15 第2章 MVC

架構:表現層分離 16 2.1 什麼是MVC 16 2.1.1 MVC的誕生 16 2.1.2 MVC的分層與職責 17 2.1.3 MVC在移動開發中的爭議 18 2.2 MVC的模式 19 2.2.1 被動模式 19 2.2.2 主動模式 19 2.2.3 觀察者模式 20 2.2.4 被動模式與主動模式的區別 21 2.3 MVC的核心思想 21 2.4 小結 22 第3章 實戰:基於MVC架構設計的日記App 23 3.1 層級職責劃分 23 3.2 準備階段 24 3.2.1 準備、創建View 24 3.2.2 清單檔Manifest配置 26 3.2.3 初始化Fragment

27 3.3 創建View 28 3.4 資料處理 31 3.4.1 創建Model 31 3.4.2 創建本地資料來源 32 3.4.3 資料持久化工具 33 3.4.4 實現本地資料來源 34 3.4.5 填充測試資料 36 3.4.6 使用資料倉庫管理資料 37 3.5 創建Controller 40 3.5.1 Controller初始化 40 3.5.2 創建Adapter 41 3.5.3 創建ViewHolder 43 3.5.4 Controller的協調工作 44 3.6 運行App 48 3.7 實現主動模式的MVC 49 3.7.1 改造Model 49 3.7.2 註

冊觀察者 50 3.8 小結 50 第4章 MVP架構:開始解耦 52 4.1 什麼是MVP 52 4.1.1 MVP架構的起源 52 4.1.2 MVP的分層與職責 52 4.2 MVP的核心思想 53 4.2.1 面向介面程式設計 53 4.2.2 德墨忒爾定律 54 4.3 MVP與MVC的區別 55 4.4 MVP模式存在的問題 56 4.4.1 責任過重的Presenter 56 4.4.2 業務邏輯無法複用 56 4.4.3 急劇擴增的介面數量 57 4.5 如何解決Presenter的複用問題 57 4.5.1 提供工具類 57 4.5.2 提供多對一的Presenter 57

4.5.3 分離出Interactor層 58 4.6 小結 59 第5章 實戰:MVP架構設計 60 5.1 層級職責劃分 60 5.2 準備工作 60 5.2.1 定義基礎View介面 60 5.2.2 定義基礎Presenter介面 61 5.3 重構:從MVC到MVP 61 5.3.1 創建Presenter 61 5.3.2 改造View 62 5.3.3 傳入Presenter實例 63 5.3.4 開發過程中Presenter和View的直接依賴 63 5.3.5 Presenter生命週期的處理 64 5.3.6 列表Adapter的處理 64 5.3.7 展示資料的處理

65 5.3.8 對話方塊展示的處理 67 5.3.9 功能表的處理 68 5.3.10 實現面向介面設計 69 5.3.11 建立契約類 69 5.4 實現MVP模式:日記修改功能 70 5.4.1 創建日記修改Activity 71 5.4.2 創建日記修改Fragment 72 5.4.3 添加“完成”按鈕 74 5.4.4 創建日記修改Presenter 75 5.4.5 日記操作處理 76 5.4.6 頁面跳轉處理 77 5.4.7 刪除舊有的修改日記UI 78 5.4.8 修改為面向介面設計 79 5.5 小結 79 第6章 MVVM架構:雙向綁定 81 6.1 什麼是MVVM

81 6.1.1 MVVM架構的起源 81 6.1.2 MVVM的分層與職責 82 6.2 MVVM的核心思想 82 6.2.1 進一步解耦 82 6.2.2 資料驅動 83 6.2.3 雙向綁定 83 6.3 架構模式對比 84 6.3.1 MVC與MVVM 84 6.3.2 MVP與MVVM 85 6.4 MVVM存在的問題 86 6.4.1 ViewModel難以複用 86 6.4.2 學習成本高 86 6.4.3 調試困難 86 6.5 小結 87 第7章 實戰:MVVM架構設計 88 7.1 什麼是DataBinding 88 7.2 重構:從MVP到MVVM 88 7.2.1 配

置DataBinding支援 89 7.2.2 修改Presenter為ViewModel 89 7.2.3 消除契約類 90 7.2.4 轉換佈局檔 92 7.2.5 在佈局中加入變數和運算式 93 7.2.6 ViewModel繼承BaseObservable 94 7.2.7 在XML佈局檔中定義清單資料屬性 95 7.2.8 使用BindingAdapter處理自訂屬性 97 7.2.9 繪製View佈局 98 7.2.10 為View屬性賦值 99 7.2.11 找到XML中的View 100 7.2.12 ObservableField原理 100 7.2.13 使用Observa

bleField 101 7.2.14 使用ObservableList 103 7.3 小結 104 第8章 依賴注入:Dagger2鋒利的“匕首” 105 8.1 什麼是Dagger 105 8.1.1 依賴注入 105 8.1.2 編譯時注解解析 107 8.2 實現:將Dagger2加入MVP 108 8.2.1 配置Dagger2 108 8.2.2 確定資料倉庫改造目標 108 8.2.3 改造資料倉庫 109 8.2.4 Inject注解 110 8.2.5 Component注解 111 8.2.6 Module注解 114 8.2.7 Provides注解 115 8.2.

8 Scope注解 117 8.2.9 Singleton注解 117 8.2.10 Scope注解和Singleton注解的實現原理 118 8.2.11 日記清單模組依賴關係分析 120 8.2.12 創建日記清單模組Component 120 8.2.13 創建日記列表Presenter Module 121 8.2.14 Component的dependencies屬性 123 8.3 存在的問題 125 8.3.1 學習成本極高 125 8.3.2 短期內開發效率低 125 8.3.3 靈活性不良好 126 8.4 小結 126 第9章 函數回應式框架:優雅的RxJava2 127

9.1 什麼是RxJava 127 9.2 RxJava2的核心思想 128 9.2.1 函數回應式程式設計 128 9.2.2 背壓 129 9.2.3 鏈式調用 129 9.3 實戰:將RxJava2加入MVP 130 9.3.1 配置RxJava2 130 9.3.2 Flowable 131 9.3.3 回應式拉取 132 9.3.4 修改資料來源介面 133 9.3.5 修改本地資料來源 133 9.3.6 Just操作符 134 9.3.7 Empty操作符 135 9.3.8 FromIterable操作符 135 9.3.9 To操作符 136 9.3.10 Subscrib

er和事件流 137 9.3.11 修改資料倉庫 137 9.3.12 FlatMap操作符 139 9.3.13 Map操作符 140 9.3.14 修改Presenter 141 9.3.15 CompositeDisposable和Disposable 142 9.3.16 Presenter生命週期 143 9.4 存在的問題 144 9.5 小結 144 第10章 AAC:搭建生命週期感知架構 145 10.1 什麼是AAC 145 10.2 AAC的核心思想 146 10.2.1 關注點分離 146 10.2.2 模型驅動介面 147 10.3 ViewModel LiveDat

a 148 10.3.1 DataBinding 148 10.3.2 Gradle依賴配置 149 10.3.3 AAC中的ViewModel 149 10.3.4 使用ViewModel 150 10.3.5 使用ViewModelProviders創建ViewModel 151 10.3.6 什麼是LiveData 152 10.3.7 MutableLiveData 153 10.3.8 創建LiveData 154 10.3.9 LiveData更新 155 10.3.10 LiveData接收變化 156 10.4 LifeCycle 156 10.4.1 生命週期 157 10.

4.2 LifecycleObserver 158 10.4.3 LifecycleOwner 159 10.5 Room 160 10.5.1 Room的組成 160 10.5.2 實體 161 10.5.3 資料訪問物件DAO 163 10.5.4 Room依賴配置 164 10.5.5 定義實體 164 10.5.6 創建Dao 165 10.5.7 創建資料庫管理器 166 10.5.8 執行緒 168 10.5.9 修改本地資料來源 169 10.5.10 資料庫升級 172 10.6 小結 173 第11章 組件化架構:極速運行 174 11.1 什麼是組件化 174 11.2

組件化的核心思想 175 11.2.1 軟體複用 175 11.2.2 信息隱藏 176 11.2.3 快速運行 177 11.3 元件分離 178 11.3.1 組件層級劃分 178 11.3.2 組件劃分 179 11.3.3 創建Module 180 11.3.4 組件依賴關係 183 11.3.5 複用Gradle配置 187 11.3.6 公共資源組件 189 11.3.7 基礎組件 191 11.3.8 移動依賴 194 11.3.9 Gradle版本號管理 194 11.3.10 處理Context 197 11.3.11 公共組件 198 11.3.12 日記清單展示組件 20

0 11.3.13 日記添加修改組件 202 11.3.14 Gradle Plugin衝突 204 11.3.15 運行主Module 204 11.4 使用路由 206 11.4.1 路由配置 206 11.4.2 使用Route跳轉 207 11.4.3 攜帶參數跳轉 208 11.5 組件運行 210 11.5.1 切換開關 210 11.5.2 元件配置 212 11.5.3 Manifest檔配置 212 11.5.4 集成運行 215 11.6 組件合併 216 11.6.1 組件命名衝突 216 11.6.2 Manifest檔合併策略 217 11.6.3 資源檔衝突 218

11.6.4 資源檔合併策略 219 11.7 小結 220 第12章 The Clean Architecture:整潔的架構 221 12.1 什麼是The Clean Architecture 221 12.2 The Clean Architecture的核心思想 222 12.2.1 單向依賴規則 222 12.2.2 業務規則分離 223 12.2.3 簡單資料結構跨界 224 12.3 MVP-Clean架構 224 12.3.1 用例的請求資料和回應資料 224 12.3.2 用例的資料處理 226 12.3.3 用例的執行緒切換 228 12.3.4 創建用例 229 1

2.3.5 執行用例 230 12.3.6 封裝請求數據 231 12.3.7 創建日記更新 推薦序 Android系統自Google 2008年發佈以來, 經過十多年的發展,已經佔據了手持設備八成以上的市場份額。在此過程中,有很多非常優秀的開發者加入這個行業,移動開發經過近幾年的快速蓬勃發展,在傳統的設計思想上有了更多的更新和創新,同時也湧現出不少高效的工具。 軟體架構是對軟體整體結構與元件的抽象描述,但在實際專案和產品反覆運算中,架構不僅涉及軟體本身,還涉及團隊組成、業務現狀及發展方向、團隊文化、投入產出比等多方面。如何基於業務做出更合理的設計?如何平衡業務和技術?

如何在做出決策後順利落地?從這些方面考慮,需要明確以下幾個問題: ·通用的架構有哪些? ·每個架構的適用場景和優缺點是什麼? ·架構的設計原則是什麼? ·架構之間是如何演化的? ·在架構設計實戰的過程中會遇到哪些問題?該如何解決? 作者從架構的定義開始,對MVC、MVP、MVVM等多種架構模式進行了詳細的闡述,並輔以案例講解。通過講解多個實戰案例回答了上述問題。本書非常適合移動開發領域的初、中級工程師閱讀,也適合高級工程師閱讀,以作參考。 ——網易新聞技術總監 劉棉明  

子由數學小學堂 Android App 開發:操作介面設計

為了解決MVC,MVP的問題,作者吳均熠 這樣論述:

「子由數學小學堂 App 開發」是為了因應智慧型手機的普及,使用者越來越多的情況下,從網頁版子由數學小學堂的加以改良成適合使用平板介面做題的 App 軟體。子由數學小學堂 App 主要有四大功能,分別為「快速出題」、「精選試卷」、「試卷紀錄」以及「題庫樂園」,其中「試卷紀錄」以及「題庫樂園」為 App 版本新增的功能。本篇論文主要介紹 App 中四大功能的前端操作設計架構以及圖片在不同平板上的自適應方法,後端程式設計請參考(簡寬宇)[1] 。

Learning JavaScript Design Patterns

為了解決MVC,MVP的問題,作者Osmani, Addy 這樣論述:

With Learning JavaScript Design Patterns, you'll learn how to write beautiful, structured, and maintainable JavaScript by applying classical and modern design patterns to the language. If you want to keep your code efficient, more manageable, and up-to-date with the latest best practices, this book

is for you.Explore many popular design patterns, including Modules, Observers, Facades, and Mediators. Learn how modern architectural patterns--such as MVC, MVP, and MVVM--are useful from the perspective of a modern web application developer. This book also walks experienced JavaScript developers th

rough modern module formats, how to namespace code effectively, and other essential topics.Learn the structure of design patterns and how they are writtenUnderstand different pattern categories, including creational, structural, and behavioralWalk through more than 20 classical and modern design pat

terns in JavaScriptUse several options for writing modular code--including the Module pattern, Asyncronous Module Definition (AMD), and CommonJSDiscover design patterns implemented in the jQuery libraryLearn popular design patterns for writing maintainable jQuery plug-ins"This book should be in ever

y JavaScript developer's hands. It's the go-to book on JavaScript patterns that will be read and referenced many times in the future."--Andr e Hansson, Lead Front-End Developer, presis Addy Osmani is a Developer Programs Engineer at Google, working on tools for improving how developers create app

lications. He’s also a member of the jQuery team where he assists with documentation and our learning site project. Some of his other OS work has included contributions to Modernizr and other similar projects. Personal projects include TodoMVC, which helps developers compare JavaScript MVC framework

s and jQuery UI Bootstrap. He also wrote ’Developing Backbone.js Applications’ and ’Learning JavaScript Design Patterns’ and occasionally tech review books like ’JavaScript Web Applications’. His personal blog is addyosmani.com/blog/.

基於物聯網的多手機應用程式端之智慧系統的開發與資料整合

為了解決MVC,MVP的問題,作者李如昀 這樣論述:

時至今日物聯網的開發處處可見,也出現了越來越多的物聯網殭屍應用程式,如何做到不讓應用程式變成殭屍App也是一門直得探討的學問。Yahoo執行長Marissa Mayer提出了「兩次點擊原則(The Two Tap Rule)」,也成了現今應用程式開發的方向,本研究透過將每一套系統由不同應用程式個別開發,讓每個應用程式保有原本的功能專一性,再透過廣告或是商店的方式,推薦使用者下載,並且每個應用程式都有能力跳轉於彼此,不同應用程式雖然在雲端是綁定不同的資料庫,但他們卻共同指向同一個資料倉儲,因此可以將每個App中使用者的資訊收集彙整。以往人們常常使用手機應用程式完成許多方便的事,例如:訂車票、預

約餐廳或記帳等等,但是產生的這些資料卻分散零閃,所以本研究將開發的應用程式包括智慧交通的停車系統、人體乳酸的顯示及收集、智慧消防與飲食紀錄等等的資料有效的收集並且統整,長時間下來將這些資料合併再一起並且產生新的價值,小至影響人們的一天起居,大至對醫學界也會有所貢獻。