成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

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

Muninn / 3163人閱讀

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

相關(guān)文章

  • 淺析 web 前端 MVVM

    摘要:它由微軟架構(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ì)是...

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

    摘要:目前它還未正式發(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)于布局...

    bergwhite 評(píng)論0 收藏0
  • 前端框架模式變遷

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

    ssshooter 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<