日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MVC架構(gòu)模式為什么悄然消失了

汽車玩家 ? 來源:今日頭條 ? 作者:令狐沖學(xué)Java ? 2020-04-12 19:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

投身IT江湖,就像打王者榮耀一樣,好不容易練會了一個硬性,結(jié)果天美把它削弱了,你不得不再去練習(xí)一個。

MVC這門技術(shù)伴隨著我的成長,感情和Java一樣深厚,但是,最近兩年卻不得不和MVC說再見了。是的,不是Struts沒了,也不是SpringMVC沒了,而是MVC這種架構(gòu)模式被淘汰了。當(dāng)時代拋棄你時,連一聲再見都不會說。所以,看到這篇文章的各位程序員兄弟們,緊跟技術(shù)發(fā)展趨勢,再牛逼一點的,能夠提前預(yù)見技術(shù)趨勢,提前準(zhǔn)備,最牛逼的,引領(lǐng)技術(shù)趨勢,咳咳,想的有點多。

我們先回顧一下MVC吧,就像懷念一個老朋友。

MVC模式(Model–view–controller)是軟件工程中的一種軟件架構(gòu)模式,把軟件系統(tǒng)分為三個基本部分:模型(Model)、視圖(View)和控制器(Controller)。( 摘自 維基百科-MVC )

模型(Model)用于封裝與應(yīng)用程序的業(yè)務(wù)邏輯相關(guān)的數(shù)據(jù)以及對數(shù)據(jù)的處理方法。“ Model ”有對數(shù)據(jù)直接訪問的權(quán)力,“Model”不依賴“View”和“Controller”,Model 不關(guān)心它會被如何顯示或是如何被操作。但是 Model 中數(shù)據(jù)的變化一般會通過一種刷新機制被公布。為了實現(xiàn)這種機制,那些用于監(jiān)視此 Model 的 View 必須事先在此 Model 上注冊,從而,View 可以了解在數(shù)據(jù) Model 上發(fā)生的改變。

視圖(View)能夠?qū)崿F(xiàn)數(shù)據(jù)有目的的顯示。在 View 中一般沒有程序上的邏輯。為了實現(xiàn) View 上的刷新功能,View 需要訪問它監(jiān)視的數(shù)據(jù)模型(Model),因此應(yīng)該事先在被它監(jiān)視的數(shù)據(jù)那里注冊。

控制器(Controller)起到不同層面間的組織作用,用于控制應(yīng)用程序的流程。它處理事件并作出響應(yīng)?!笆录卑ㄓ脩舻男袨楹蛿?shù)據(jù) Model 上的改變。

Struts和SpringMVC曾經(jīng)是MVC雙雄。

那是什么導(dǎo)致MVC模式被淘汰了呢?移動時代的到來,展示端愈來愈重要,所以前端技術(shù)發(fā)展越來越猛烈,前端工程師也不再是團隊的小弟了,他們要求和Java工程師平等對話。

前后端分離來了,Node.js來了,前端工程師把MVC的職責(zé)都給搶走了,后端工程師真正成為了后端,只需要提供API給前端就行,再也不用關(guān)心redirectforward有什么區(qū)別,再也不用關(guān)心session、cookies有什么區(qū)別,怎么樣。當(dāng)前端工程師拿走MVC的職責(zé)之后,自然會把MVC模式改成更適合前端的模式:MVVM。

MVVM(Model–View–Viewmodel)也是一種軟件架構(gòu)模式,它必將取代MVC,或者說的好聽一些,它是MVC基礎(chǔ)上演化而來。

MVC中的M就是單純的從網(wǎng)絡(luò)獲取回來的數(shù)據(jù)模型,V指的我們的視圖界面,而C就是我們的ViewController。

在其中,ViewController負責(zé)View和Model之間調(diào)度,View發(fā)生交互事件會通過target-action或者delegate方式回調(diào)給ViewController,與此同時ViewController還要承擔(dān)把Model通過KVO、Notification方式傳來的數(shù)據(jù)傳輸給View用于展示的責(zé)任。隨著業(yè)務(wù)越來越復(fù)雜,視圖交互越復(fù)雜,導(dǎo)致Controller越來越臃腫,負重前行。臟活累活都它干了,到頭來還一點不討好。福報修多了的結(jié)果就是,不行了就重構(gòu)你,重構(gòu)不了就換掉你。

來一張斯坦福老頭經(jīng)典的MVC架構(gòu)圖。

所以為了解決這個問題,MVVM就閃亮登場了。他把View和Contrller都放在了View層(相當(dāng)于把Controller一部分邏輯抽離了出來),Model層依然是服務(wù)端返回的數(shù)據(jù)模型。而ViewModel充當(dāng)了一個UI適配器的角色,也就是說View中每個UI元素都應(yīng)該在ViewModel找到與之對應(yīng)的屬性。除此之外,從Controller抽離出來的與UI有關(guān)的邏輯都放在了ViewModel中,這樣就減輕了Controller的負擔(dān)。

這張圖是從網(wǎng)上找的,MVVM還在學(xué)習(xí)階段,后續(xù)補一張自己的

從以上的架構(gòu)圖中,我們可以很清晰的梳理出各自的分工。

View層:視圖展示。包含UIView以及UIViewController,View層是可以持有ViewModel的。

ViewModel層:視圖適配器。暴露屬性與View元素顯示內(nèi)容或者元素狀態(tài)一一對應(yīng)。一般情況下ViewModel暴露的屬性建議是readOnly的,至于為什么,我們在實戰(zhàn)中會去解釋。還有一點,ViewModel層是可以持有Model的。

Model層:數(shù)據(jù)模型與持久化抽象模型。數(shù)據(jù)模型很好理解,就是從服務(wù)器拉回來的JSON數(shù)據(jù)。而持久化抽象模型暫時放在Model層,是因為MVVM誕生之初就沒有對這塊進行很細致的描述。按照經(jīng)驗,我們通常把數(shù)據(jù)庫、文件操作封裝成Model,并對外提供操作接口。(有些公司把數(shù)據(jù)存取操作單拎出來一層,稱之為DataAdapter層,所以在業(yè)內(nèi)會有很多MVVM的變種,但其本質(zhì)上都是MVVM)。

Binder:MVVM的靈魂。可惜在MVVM這幾個英文單詞中并沒有它的一席之地,它的最主要作用是在View和ViewModel之間做了雙向數(shù)據(jù)綁定。如果MVVM沒有Binder,那么它與MVC的差異不是很大。

總結(jié)來說,MVC模式本來是完美的,但是隨著移動時代的到來,前端數(shù)據(jù)展示、交互、跳轉(zhuǎn)變得復(fù)雜了,Controller的只能真的不適合在放到后端了,所以MVVM就出現(xiàn)了。

后面的文章中會繼續(xù)闡述MVVM、SPA等前端的架構(gòu)模型,就像練一個天美的新英雄一樣。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    3012

    瀏覽量

    116874
  • MVC
    MVC
    +關(guān)注

    關(guān)注

    0

    文章

    73

    瀏覽量

    14494
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    京東緩存中間件架構(gòu)與緩存內(nèi)核優(yōu)化

    一、京東緩存中間件架構(gòu) 1、背景 在當(dāng)今高并發(fā)、分布式的系統(tǒng)架構(gòu)中,緩存已成為提升應(yīng)用性能、降低數(shù)據(jù)庫負載的核心組件。隨著業(yè)務(wù)規(guī)模的擴大與系統(tǒng)復(fù)雜度的增加,緩存的使用和管理面臨諸多挑戰(zhàn):部署模式多樣
    的頭像 發(fā)表于 04-03 16:18 ?1829次閱讀
    京東緩存中間件<b class='flag-5'>架構(gòu)</b>與緩存內(nèi)核優(yōu)化

    探索TRAC020LH:完全可重構(gòu)模擬電路的卓越之選

    探索TRAC020LH:完全可重構(gòu)模擬電路的卓越之選 在模擬信號處理的領(lǐng)域中,不斷追求更高效、更靈活的解決方案是電子工程師們永恒的目標(biāo)。今天,我們就來深入了解一款備受矚目的產(chǎn)品——TRAC020LH
    的頭像 發(fā)表于 03-27 14:30 ?175次閱讀

    Redis哨兵模式的自動故障檢測與主從切換實戰(zhàn)

    Redis 主從復(fù)制解決讀擴展和數(shù)據(jù)冗余問題,但主節(jié)點故障時需要人工介入切換,這在生產(chǎn)環(huán)境中是不可接受的。Sentinel(哨兵)模式在主從架構(gòu)之上增加了自動故障檢測和故障轉(zhuǎn)移能力,是 Redis 高可用的標(biāo)準(zhǔn)方案之一。
    的頭像 發(fā)表于 02-27 11:05 ?321次閱讀

    LAT1199+TrustZone 架構(gòu)下使用 LPBAM 導(dǎo)致的 HardFault應(yīng)用筆記

    客戶在 Nucleo-U575ZI 開發(fā)板上使用 TrustZone 架構(gòu),測試 LPBAM 功能。首先使能 TrustZone 架構(gòu),然后將 LPGPIO 映射到了非安全區(qū),并且配置
    發(fā)表于 01-11 17:23 ?0次下載

    芯源MCU架構(gòu)是不是基本都是ARM架構(gòu)?還有其他的架構(gòu)嗎?

    芯源MCU架構(gòu)是不是基本都是ARM架構(gòu)?還有其他的架構(gòu)嗎?
    發(fā)表于 11-20 06:21

    浮點舍入模式介紹(六)

    模式(Rounding Mode), RISC-V 架構(gòu)浮點運算的舍入模式可以通過兩種方式指定。 (1)靜態(tài)舍入模式:浮點指令的編碼中有3位作為舍入
    發(fā)表于 10-24 07:57

    yaffs文件系統(tǒng)能掛載成功,掉電消失,為什么?

    上電會消失。 代碼里創(chuàng)建文件夾卻失敗。顯示錯誤,返回值-28. 求助大佬。NAND Flash型號是MT29F64G08AFAAAWP。stm32f407。
    發(fā)表于 10-13 07:50

    什么是ARM架構(gòu)?你需要知道的一切

    從智能手機到工業(yè)邊緣計算機,ARM?架構(gòu)為全球數(shù)十億臺設(shè)備提供動力。ARM?以其效率優(yōu)先的設(shè)計和靈活的許可模式而聞名,已迅速從移動處理器擴展到人工智能邊緣計算、工業(yè)控制器,甚至數(shù)據(jù)中心。本文我們將
    的頭像 發(fā)表于 09-11 14:48 ?1745次閱讀
    什么是ARM<b class='flag-5'>架構(gòu)</b>?你需要知道的一切

    GNSS模擬器核心架構(gòu)如何實現(xiàn)?技術(shù)主管深度解讀設(shè)計原理

    本文聚焦GNSS模擬器技術(shù)領(lǐng)域的核心難點,包括系統(tǒng)組成與核心引擎,GNSS頻段基礎(chǔ),控制模式架構(gòu)理念
    的頭像 發(fā)表于 07-29 14:58 ?736次閱讀
    GNSS模擬器核心<b class='flag-5'>架構(gòu)</b>如何實現(xiàn)?技術(shù)主管深度解讀設(shè)計原理

    飛睿UWB超寬帶定位測距技術(shù),數(shù)字鑰匙重塑智能生活,高精度厘米級定位無感解鎖

    鑰匙消失,門卻更懂你。當(dāng)厘米級定位遇見空間感知,一場從“主動操作”到“無感響應(yīng)”的智能革命已悄然到來。
    的頭像 發(fā)表于 07-15 15:23 ?1188次閱讀
    飛睿UWB超寬帶定位測距技術(shù),數(shù)字鑰匙重塑智能生活,高精度厘米級定位無感解鎖

    晶體管架構(gòu)的演變過程

    芯片制程從微米級進入2納米時代,晶體管架構(gòu)經(jīng)歷從 Planar FET 到 MBCFET的四次關(guān)鍵演變。這不僅僅是形狀的變化,更是一次次對物理極限的挑戰(zhàn)。從平面晶體管到MBCFET,每一次架構(gòu)演進到底解決
    的頭像 發(fā)表于 07-08 16:28 ?2539次閱讀
    晶體管<b class='flag-5'>架構(gòu)</b>的演變過程

    AMD FPGA異步模式與同步模式的對比

    本文講述AMD UltraScale /UltraScale+ FPGA 原生模式下,異步模式與同步模式的對比及其對時鐘設(shè)置的影響。
    的頭像 發(fā)表于 07-07 13:47 ?1821次閱讀

    Vector全流程開發(fā)工具鏈概述

    在軟件定義汽車(SDV)時代,汽車軟件的復(fù)雜度和重要性顯著提升,開發(fā)模式也逐步從基于ECU的獨立軟件開發(fā)向集中化、平臺化的軟件架構(gòu)演進。傳統(tǒng)的開發(fā)模式由于硬件與軟件緊耦合,導(dǎo)致升級難度大、開發(fā)周期長
    的頭像 發(fā)表于 06-17 13:45 ?1350次閱讀
    Vector全流程開發(fā)工具鏈概述

    主流版本控制工具Git vs Perforce P4:架構(gòu)模式、性能、大文件管理及分支管理對比詳解

    Git vs Perforce P4,如何選型?架構(gòu)模式、性能、大文件管理、分支策略四大維度對比,幫你全面了解兩者的核心差異,選擇更合適你團隊需求的版本控制系統(tǒng)。
    的頭像 發(fā)表于 06-13 14:52 ?973次閱讀
    主流版本控制工具Git vs Perforce P4:<b class='flag-5'>架構(gòu)模式</b>、性能、大文件管理及分支管理對比詳解

    服務(wù)器數(shù)據(jù)恢復(fù)—服務(wù)器重裝系統(tǒng)導(dǎo)致分區(qū)消失的數(shù)據(jù)恢復(fù)案例

    服務(wù)器上有一組由raid卡組建的raid5磁盤陣列。上層安裝linux才做系統(tǒng),采用XFS文件系統(tǒng),劃分了3個分區(qū)。 管理員將服務(wù)器的操作系統(tǒng)重裝后,發(fā)現(xiàn)服務(wù)器上的分區(qū)發(fā)生了改變:一個分區(qū)消失,其他分區(qū)不可訪問。
    的頭像 發(fā)表于 05-14 10:13 ?757次閱讀
    服務(wù)器數(shù)據(jù)恢復(fù)—服務(wù)器重裝系統(tǒng)導(dǎo)致分區(qū)<b class='flag-5'>消失</b>的數(shù)據(jù)恢復(fù)案例
    都昌县| 益阳市| 新化县| 隆安县| 宁武县| 昌图县| 寻乌县| 成武县| 龙州县| 涟水县| 平泉县| 南宁市| 嵩明县| 大名县| 南和县| 舒城县| 四川省| 杭州市| 临江市| 克什克腾旗| 轮台县| 湛江市| 阿坝| 凌源市| 伊川县| 阳信县| 丰镇市| 盐边县| 昌图县| 凌云县| 锡林郭勒盟| 安多县| 科技| 灵寿县| 井冈山市| 高雄县| 屏山县| 佛冈县| 常熟市| 永胜县| 当阳市|