国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

對MVVM架構(gòu)的一些理解

Muninn / 3157人閱讀

MVVM(Model-View-ViewModel)是在MVC(Model-View-Control)模式之后引出的新的開發(fā)模式,他與MVC
模式一樣用于把視圖(界面)和數(shù)據(jù)進(jìn)行解耦,不同的是采用ViewModel來完成數(shù)據(jù)與視圖的雙向綁定,通
過自動化的方式承擔(dān)大部分?jǐn)?shù)據(jù)工作,來解決由于界面復(fù)雜化和快速迭代帶來的問題。

由于現(xiàn)在vue比較火,現(xiàn)在就用vue相同的原理(屬性劫持)來完成一個簡單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ù)對象(Model),與dom綁定的數(shù)據(jù)都在這兒

var Model = {
    msg:"hello world",
    msg2:"hello world2"
};

視圖對象(View),里面封裝了對dom節(jié)點的解析、事件綁定、視圖更新渲染等方法

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];
        }
    }
};

視圖模板綁定對象(ViewModel),這也是mvvm實現(xiàn)的核心方法,通過defineProperty將Model對象中的數(shù)據(jù)
復(fù)制到了View對象中,并對數(shù)據(jù)進(jìn)行了監(jiān)控,每當(dāng)get或set時都會觸發(fā)自定義事件,完成對視圖的跟新。

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對象的初始化方法執(zhí)行框架,至此就完成了一個簡單的MVVM框架。

View.init("#app");

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/94727.html

相關(guān)文章

  • 淺析 web 前端 MVVM

    摘要:它由微軟架構(gòu)師和開發(fā),通過利用微軟圖形系統(tǒng)和的互聯(lián)網(wǎng)應(yīng)用派生品的特性來簡化用戶界面的事件驅(qū)動程序設(shè)計。微軟的和架構(gòu)師之一于年在他的博客上發(fā)表了。更改時會得到提醒這個情況是一個單向流。 前言 記得四個月前有一次面試,面試官問我 MVVM 是什么,MVVM 的本質(zhì)是什么。我大腦一片混亂,那時我對 MVVM 的認(rèn)知就只是雙向綁定和Vue,以這個關(guān)鍵字簡單回答了幾句,我反問 MVVM 的本質(zhì)是...

    VincentFF 評論0 收藏0
  • Android架構(gòu)

    摘要:目前它還未正式發(fā)布。理解系列一是谷歌在發(fā)布一套幫助開發(fā)者解決架構(gòu)設(shè)計的方案。但最近還是推出了一份關(guān)于應(yīng)用架構(gòu)的實踐指南,并給出了相當(dāng)詳盡的步驟和一些指導(dǎo)建議。 MVP+Retrofit+Rxjava在項目中實戰(zhàn)解析 文章目標(biāo) MVP在android中的原理解析 MVP+Retrofit+Rxjava在項目中實戰(zhàn)解析 架構(gòu)經(jīng)驗分享 MVP簡單介紹 先說說MVC分層: View:對應(yīng)于布局...

    bergwhite 評論0 收藏0
  • 前端框架模式變遷

    摘要:現(xiàn)在在前端的框架都是的模式,還有像和之類的變種獨特的單向數(shù)據(jù)流框架。只要將數(shù)據(jù)流進(jìn)行規(guī)范,那么原來的模式還是大有可為的。我們可以來看一下,框架的圖示從圖中,我們可以看到形成了一條到,再到,之后是的,一條單向數(shù)據(jù)流。 前言 前端框架的變遷,體系架構(gòu)的完善,使得我們只知道框架,卻不明白它背后的道理。我們應(yīng)該抱著一顆好奇心,在探索框架模式的變遷過程中,體會前人的一些理解和思考 本篇將講述的是...

    ssshooter 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<