MVVM模式中ViewModel和View、Model有什麼差別? _javascript技巧
Model:很簡單,就是業務邏輯相關的資料對象,通常從資料庫映射而來,我們可以說是與資料庫對應的model。
View:也很簡單,就是展現出來的使用者介面。
基本上,絕大多數軟體所做的工作無非就是從數據存儲中讀出數據,展現到用戶界面上,然後從用戶界面接收輸入,寫入到數據存儲裡面去。所以,對於資料儲存(model)和介面(view)這兩層,大家基本上沒什麼異議。但是,如何把model展現到view上,以及如何把資料從view寫入到model裡,不同的人有不同的意見。
MVC派的看法是,介面上的每個變化都是一個事件,我只需要針對每個事件寫一堆程式碼,來把使用者的輸入轉換成model裡的物件就行了,這堆程式碼可以叫controller。
而MVVM派的看法是,我給view裡面的各種控制也定義一個對應的資料對象,這樣,只要修改這個資料對象,view裡面顯示的內容就自動跟著刷新,而在view 裡做了任何操作,這個資料物件也跟著自動更新,這樣多美。所以:
ViewModel:就是與介面(view)對應的Model。因為,資料庫結構往往是不能直接跟介面控制一一對應上的,所以,需要再定義一個資料物件專門對應view上的控制項。而ViewModel的職責就是把model物件封裝成可以顯示和接受輸入的介面資料物件。
至於viewmodel的資料隨著view自動刷新,並且同步到model裡去,這部分程式碼可以寫成公用的框架,不用程式設計師自己操心了。
簡單的說,ViewModel就是View與Model的連接器,View與Model透過ViewModel實現雙向綁定。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題











C語言函數是代碼模塊化和程序搭建的基礎。它們由聲明(函數頭)和定義(函數體)組成。 C語言默認使用值傳遞參數,但也可使用地址傳遞修改外部變量。函數可以有返回值或無返回值,返回值類型必須與聲明一致。函數命名應清晰易懂,使用駝峰或下劃線命名法。遵循單一職責原則,保持函數簡潔性,以提高可維護性和可讀性。

H5、小程序和APP的主要區別在於:技術架構:H5基於網頁技術,小程序和APP為獨立應用程序。體驗和功能:H5輕便易用,功能受限;小程序輕量級,交互性好;APP功能強大,體驗流暢。兼容性:H5跨平台兼容,小程序和APP受平台限制。開發成本:H5開發成本低,小程序中等,APP最高。適用場景:H5適合信息展示,小程序適合輕量化應用,APP適合複雜功能應用。

C語言函數是可重複利用的代碼塊,它接收輸入,執行操作,返回結果,可將代碼模塊化提高可複用性,降低複雜度。函數內部機制包含參數傳遞、函數執行、返回值,整個過程涉及優化如函數內聯。編寫好的函數遵循單一職責原則、參數數量少、命名規範、錯誤處理。指針與函數結合能實現更強大的功能,如修改外部變量值。函數指針將函數作為參數傳遞或存儲地址,用於實現動態調用函數。理解函數特性和技巧是編寫高效、可維護、易理解的C語言程序的關鍵。

在 Photoshop 中導出帶密碼保護的 PDF:打開圖像文件。點擊“文件”>“導出”>“導出為 PDF”。設置“安全性”選項,兩次輸入相同的密碼。點擊“導出”生成 PDF 文件。

在router文件夾下的index.js文件中註冊VueRouter的必要性在開發Vue應用程序時,常常會遇到關於路由配置的問題。特�...

C和C#雖有類似之處,但截然不同:C是面向過程、手動內存管理、平台依賴的語言,用於系統編程;C#是面向對象、垃圾回收、平台獨立的語言,用於桌面、Web應用和遊戲開發。

DOM節點下XPath查找方法詳解在JavaScript中,我們經常需要根據XPath表達式從DOM樹中查找特定的節點。如果需要從某�...

深入探討console.log輸出差異本文將分析一段代碼中console.log函數輸出結果不同的原因。代碼片段涉及URL參數解析�...
