欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue.js 和 MVVM 的注意事項

 更新時間:2016年11月07日 13:39:27   作者:一像素  
MVVM 是Model-View-ViewModel 的縮寫,它是一種基于前端開發(fā)的架構模式,Vue.js 是一個提供 MVVM 風格的雙向數(shù)據(jù)綁定的 Javascript 庫,專注于View 層。這篇文章給大家介紹Vue.js 和 MVVM 的注意事項,感興趣的朋友一起看看吧

MVVM 是Model-View-ViewModel 的縮寫,它是一種基于前端開發(fā)的架構模式,其核心是提供對View 和 View Model 的雙向數(shù)據(jù)綁定,這使得View Model的狀態(tài)改變可以自動傳遞給 View,這就是所謂的數(shù)據(jù)雙向綁定。

Vue.js 是一個提供 MVVM 風格的雙向數(shù)據(jù)綁定的 Javascript 庫,專注于View 層。它的核心是 MVVM 中的 VM,也就是 ViewModel。ViewModel負責連接 View 和 Model,保證視圖和數(shù)據(jù)的一致性,這種輕量級的架構讓前端開發(fā)更加高效、便捷。

為什么會出現(xiàn) MVVM 呢?

我接觸MVVM 是在2015年,可以說2015年是MVVM 最火熱的一年,而在這之前,我所知道的就是MVC, MVC 大約是在5年前,也就是2011年的時候接觸的,那時候剛學編程語言,學的是Java,而Java 中的經(jīng)典的 SSH 框架就用來構建一個標準的MVC 架構。說實話,MVC 架構用了這么多年,但始終沒有很深刻的理解,只停留在用的層面, 一直到接觸 Vue.js 之后,研究了MVVM 架構思想,然后再回頭看 MVC ,才有一種豁然開朗的感覺~

MVC 即 Model-View-Controller 的縮寫,就是 模型-視圖-控制器 , 也就是說一個標準的Web 應用程式是由這三部分組成的:

View 用來把數(shù)據(jù)以某種方式呈現(xiàn)給用戶

Model 其實就是數(shù)據(jù)

Controller 接收并處理來自用戶的請求,并將 Model 返回給用戶

在HTML5 還未火起來的那些年,MVC 做為Web 應用的最佳實踐是OK的,這是因為 Web 應用的View 層相對來說比較簡單,前端所需要的數(shù)據(jù)在后端基本上都可以處理好,View 層主要是做一下展示,那時候提倡的是 Controller 來處理復雜的業(yè)務邏輯,所以View 層相對來說比較輕量,就是所謂的 瘦客戶端 思想。

2010年到2011年,HTML5概念被熱炒,受到追捧,2012年,W3C 正式宣布HTML5規(guī)范已經(jīng)正式定稿。2013年我剛進公司就接觸到了一個 HTML5 框架 Sench touch, Sench touch 是一款用來構建移動應用的HTML5 框架,它將前后端徹底分離,前端采用的是MVC 架構,作為一個獨立的項目工程來維護。

為什么前端要工程化,要是使用MVC?

相對 HTML4 ,HTML5 最大的亮點是它為移動設備提供了一些非常有用的功能,使得 HTML5 具備了開發(fā)App的能力, HTML5開發(fā)App 最大的好處就是跨平臺、快速迭代和上線,節(jié)省人力成本和提交效率,因此很多企業(yè)開始對傳統(tǒng)的App進行改造,逐漸用H5代替Native頁面,到2015年的時候,市面上很多App 或多或少嵌入都了H5頁面。

既然要用H5來構建 App, 那View 層所做的事,就不僅僅是簡單的數(shù)據(jù)展示了,要管理數(shù)據(jù),管理用戶操作的各種狀態(tài),還要處理移動設備上用戶各種操作行為等等。因此,前端也需要一個類似于MVC的框架來管理這些復雜的邏輯,使開發(fā)更加高效。 但此時的 MVC 又稍微發(fā)了點變化:

View UI布局,展示數(shù)據(jù)

Model 管理數(shù)據(jù)

Controller 響應用戶操作,并將 Model 更新到 View 上

這種 MVC 架構模式對于基礎的應用來看起是OK的,更是符合軟件架構的分層思想。 但實際上,隨著H5 的不斷發(fā)展,人們更希望使用H5 開發(fā)的應用能和Native 媲美,或者接近于原生App 體驗效果,于是前端應用的復雜程度已不同往日,今非昔比。這時前端就暴露了三個重要的痛點問題:

1. 開發(fā)者在代碼中大量調用相同的 DOM API, 處理繁瑣 ,操作冗余,使得代碼難以維護。

2. 大量的DOM 操作使頁面渲染性能降低,加載速度變慢,影響用戶體驗。

3. 當 Model 頻繁發(fā)生變化,開發(fā)者需要主動更新到View ;當用戶的操作導致 Model 發(fā)生變化,開發(fā)者同樣需要將變化的數(shù)據(jù)同步到Model 中,
這樣的工作不僅繁瑣,而且很難維護復雜多變的數(shù)據(jù)狀態(tài)。
其實,早期jquery的出現(xiàn)就是為了前端能更簡潔的操作DOM,但它只解決了第一個問題,后面的兩個問題始終伴隨著前端一直存在。

MVVM 的出現(xiàn),完美的解決了以上三個問題。

MVVM 由 Model,View,ViewModel 三部分組成,Model 層代表數(shù)據(jù)模型,也可以在Model中定義數(shù)據(jù)修改和操作的業(yè)務邏輯;View 代表UI組件,它負責將數(shù)據(jù)模型轉化成UI展現(xiàn)出來,ViewModel 是一個同步View 和 Model的對象。

在MVVM架構下,View 和 Model 之間并沒有直接的聯(lián)系,而是通過ViewModel進行交互,Model和ViewModel之間的交互是雙向的, 因此View 數(shù)據(jù)的變化會同步到Model中,而Model 數(shù)據(jù)的變化也會立即反應到View上。

ViewModel 通過雙向數(shù)據(jù)綁定把 View 層和 Model 層連接了起來,而View 和 Model 之間的同步工作完全是自動的,無需人為干涉,因此開發(fā)者只需關注業(yè)務邏輯,不需要手動操作DOM,不需要關注數(shù)據(jù)狀態(tài)的同步問題,復雜的數(shù)據(jù)狀態(tài)維護完全由 MVVM 來統(tǒng)一管理。

Vue.js 的細節(jié)

Vue.js 可以說是MVVM架構的最佳實踐,專注于 MVVM 中的 ViewModel,不僅做到了數(shù)據(jù)雙向綁定,而且也是一款相對來比較輕量級的JS庫,API 簡潔,很容易上手。Vue的基礎知識網(wǎng)上有現(xiàn)成的教程,此處不再贅述, 下面簡單了解一下 Vue.js 關于雙向綁定的一些實現(xiàn)細節(jié):

Vue.js 采用的是Object.defineProperty 的getter和setter,并結合觀察者模式來實現(xiàn)數(shù)據(jù)綁定的。當把一個普通 Javascript 對象傳給 Vue 實例來作為它的 data 選項時,Vue 將遍歷它的屬性,用 Object.defineProperty 將它們轉為 getter/setter。用戶看不到 getter/setters,但是在內部它們讓 Vue 追蹤依賴,在屬性被訪問和修改時通知變化。

Observer 數(shù)據(jù)監(jiān)聽器,能夠對數(shù)據(jù)對象的所有屬性進行監(jiān)聽,如有變動可拿到最新值并通知訂閱者,內部采用Object.defineProperty的getter和setter來實現(xiàn)

Compile 指令解析器,它的作用對每個元素節(jié)點的指令進行掃描和解析,根據(jù)指令模板替換數(shù)據(jù),以及綁定相應的更新函數(shù)

Watcher 訂閱者, 作為連接 Observer 和 Compile 的橋梁,能夠訂閱并收到每個屬性變動的通知,執(zhí)行指令綁定的相應回調函數(shù)

Dep 消息訂閱器,內部維護了一個數(shù)組,用來收集訂閱者(Watcher),數(shù)據(jù)變動觸發(fā)notify 函數(shù),再調用訂閱者的 update 方法

當執(zhí)行 new Vue() 時,Vue 就進入了初始化階段,一方面Vue 會遍歷 data 選項中的屬性,并用 Object.defineProperty 將它們轉為 getter/setter,實現(xiàn)數(shù)據(jù)變化監(jiān)聽功能;另一方面,Vue 的指令編譯器Compile 對元素節(jié)點的指令進行掃描和解析,初始化視圖,并訂閱Watcher 來更新視圖, 此時Wather會將自己添加到消息訂閱器中(dep),初始化完畢。

當數(shù)據(jù)發(fā)生變化時,Observer 中的 setter方法被觸發(fā),setter 會立即調用Dep.notify(),Dep 開始遍歷所有的訂閱者,并調用訂閱者的 update 方法,訂閱者收到通知后對視圖進行相應的更新,完成一次數(shù)據(jù)綁定。

以上所述是小編給大家介紹的Vue.js 和 MVVM 的注意事項,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • vue中使用ts配置的具體步驟

    vue中使用ts配置的具體步驟

    這篇文章主要介紹了vue中使用ts配置的具體步驟,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue通過watch對input做字數(shù)限定的方法

    vue通過watch對input做字數(shù)限定的方法

    本篇文章主要介紹了vue通過watch對input做字數(shù)限定的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Vue匿名插槽與作用域插槽的合并和覆蓋行為

    Vue匿名插槽與作用域插槽的合并和覆蓋行為

    這篇文章主要介紹了Vue基礎-匿名插槽與作用域插槽的合并和覆蓋行為 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Vue項目API接口封裝的超詳細解答

    Vue項目API接口封裝的超詳細解答

    在前端vue的開發(fā)中,有一點是必須要做的,那就是將所有的API接口封裝起來,因為從開發(fā)到最終上線的過程中,API是需要經(jīng)常更換的,下面這篇文章主要給大家介紹了關于Vue項目API接口封裝的相關資料,需要的朋友可以參考下
    2022-09-09
  • vue中下拉框組件的封裝方式

    vue中下拉框組件的封裝方式

    這篇文章主要介紹了vue中下拉框組件的封裝方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例代碼

    Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例代碼

    Vue3是Vue.js的最新版本,它帶來了許多令人興奮的新特性和改進,其中一個重要的特性是Suspense,它為我們提供了一種優(yōu)雅地處理異步組件加載和錯誤處理的方式,本文給大家介紹了Vue3使用Suspense優(yōu)雅地處理異步組件加載的示例,需要的朋友可以參考下
    2024-01-01
  • vue中的el-form表單rule校驗問題(特殊字符、中文、數(shù)字等)

    vue中的el-form表單rule校驗問題(特殊字符、中文、數(shù)字等)

    這篇文章主要介紹了vue中的el-form表單rule校驗問題(特殊字符、中文、數(shù)字等),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue-cli腳手架搭建方式(vue腳手架方式搭建)

    vue-cli腳手架搭建方式(vue腳手架方式搭建)

    這篇文章主要介紹了vue-cli(vue腳手架方式搭建),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vue移動端監(jiān)聽滾動條高度的實現(xiàn)方法

    vue移動端監(jiān)聽滾動條高度的實現(xiàn)方法

    今天小編就為大家分享一篇vue移動端監(jiān)聽滾動條高度的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue組件化中slot的基本使用方法

    vue組件化中slot的基本使用方法

    這篇文章主要給大家介紹了關于vue組件化中slot的基本使用方法,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05

最新評論