MVVM(Model-View-ViewModel)是在MVC(Model-View-Control)模式之后引出的新的開發(fā)模式,他與MVC
模式一樣用于把視圖(界面)和數(shù)據(jù)進(jìn)行解耦,不同的是采用ViewModel來完成數(shù)據(jù)與視圖的雙向綁定,通
過自動(dòng)化的方式承擔(dān)大部分?jǐn)?shù)據(jù)工作,來解決由于界面復(fù)雜化和快速迭代帶來的問題。
由于現(xiàn)在vue比較火,現(xiàn)在就用vue相同的原理(屬性劫持)來完成一個(gè)簡單MVVM框架
創(chuàng)建dom
var html="{{msg}}{{msg2}}
{{msg}}
"; var div = document.createElement("div"); div.id="app"; div.innerHTML = html; document.body.appendChild(div);
數(shù)據(jù)對(duì)象(Model),與dom綁定的數(shù)據(jù)都在這兒
var Model = { msg:"hello world", msg2:"hello world2" };
視圖對(duì)象(View),里面封裝了對(duì)dom節(jié)點(diǎn)的解析、事件綁定、視圖更新渲染等方法
var View = { init:function(el){ //將數(shù)據(jù)與View綁定 ViewModel.bind(Model); //解析Dom this.processNode(el); }, subs:[], processNode:function(el){ var node = document.querySelector(el); var frag = document.createDocumentFragment(),child; while(child = node.firstChild){ this.compile(child); frag.appendChild(child); } node.appendChild(frag); }, compile:function(node){ function Sub(node,name,nodeType){ this.node = node; this.name = name; this.nodeType = nodeType; } var self = this; if(node.nodeType === 1){ if(node.childNodes){ var nodes =[...node.childNodes]; nodes.forEach(function(node){ self.compile(node); }) } var attrs = [...node.attributes]; attrs.forEach(function(attr){ if(attr.nodeName === "v-model"){ var name = attr.nodeValue; node.addEventListener("input",function(e){ self[name] = e.target.value; }); node.value = self[name]; node.removeAttribute("v-model"); var sub = new Sub(node,name,"input"); self.render(sub); self.subs.push(sub); } }) } if(node.nodeType === 3){ if(/{{(.*)}}/.test(node.nodeValue)){ var name = RegExp.$1; name=name.trim(); var sub = new Sub(node,name,"text"); self.render(sub); self.subs.push(sub); } } }, update:function(){ var self = this; this.subs.forEach(function(sub){ self.render(sub); }) }, render:function(sub){ if(sub.nodeType === "input"){ sub.node.value=this[sub.name]; } if(sub.nodeType === "text"){ sub.node.nodeValue=this[sub.name]; } } };
視圖模板綁定對(duì)象(ViewModel),這也是mvvm實(shí)現(xiàn)的核心方法,通過defineProperty將Model對(duì)象中的數(shù)據(jù)
復(fù)制到了View對(duì)象中,并對(duì)數(shù)據(jù)進(jìn)行了監(jiān)控,每當(dāng)get或set時(shí)都會(huì)觸發(fā)自定義事件,完成對(duì)視圖的跟新。
var ViewModel={ bind:function(m){ Object.keys(m).forEach(function(key){ Object.defineProperty(View,key,{ get:function(){ return m[key]; }, set:function(newVal){ m[key] = newVal; this.update(); } }) }); } };
最后調(diào)用View對(duì)象的初始化方法執(zhí)行框架,至此就完成了一個(gè)簡單的MVVM框架。
View.init("#app");
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/94727.html
摘要:它由微軟架構(gòu)師和開發(fā),通過利用微軟圖形系統(tǒng)和的互聯(lián)網(wǎng)應(yīng)用派生品的特性來簡化用戶界面的事件驅(qū)動(dòng)程序設(shè)計(jì)。微軟的和架構(gòu)師之一于年在他的博客上發(fā)表了。更改時(shí)會(huì)得到提醒這個(gè)情況是一個(gè)單向流。 前言 記得四個(gè)月前有一次面試,面試官問我 MVVM 是什么,MVVM 的本質(zhì)是什么。我大腦一片混亂,那時(shí)我對(duì) MVVM 的認(rèn)知就只是雙向綁定和Vue,以這個(gè)關(guān)鍵字簡單回答了幾句,我反問 MVVM 的本質(zhì)是...
摘要:目前它還未正式發(fā)布。理解系列一是谷歌在發(fā)布一套幫助開發(fā)者解決架構(gòu)設(shè)計(jì)的方案。但最近還是推出了一份關(guān)于應(yīng)用架構(gòu)的實(shí)踐指南,并給出了相當(dāng)詳盡的步驟和一些指導(dǎo)建議。 MVP+Retrofit+Rxjava在項(xiàng)目中實(shí)戰(zhàn)解析 文章目標(biāo) MVP在android中的原理解析 MVP+Retrofit+Rxjava在項(xiàng)目中實(shí)戰(zhàn)解析 架構(gòu)經(jīng)驗(yàn)分享 MVP簡單介紹 先說說MVC分層: View:對(duì)應(yīng)于布局...
閱讀 2077·2021-11-24 09:39
閱讀 795·2021-09-30 09:48
閱讀 986·2021-09-22 15:29
閱讀 2421·2019-08-30 14:17
閱讀 1895·2019-08-30 13:50
閱讀 1352·2019-08-30 13:47
閱讀 989·2019-08-30 13:19
閱讀 3428·2019-08-29 16:43