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

資訊專欄INFORMATION COLUMN

mv**中,用數(shù)據(jù)層解決多個view對應不同model的問題

tommego / 2371人閱讀

摘要:回調使用事件可以支持多個成功后的回調。實際生產(chǎn)中,如果模塊的數(shù)據(jù)層管理使用場景只有一個,也不需要在操作中做相關操作。一般只需要實例化成單例提供管理數(shù)據(jù)的相關事件到不同的組件。

說明

博文中code例子是基于nej編寫,如果你沒使用過nej,也不會妨礙你理解代碼。

適用場景

實際開發(fā)中常遇到不同model對應多個view。用戶通過 View 層來交互,View 有時需要根據(jù)用戶的數(shù)據(jù)更新 Model。還有時 Model 需要更新其他的 Model,即一個model改變,觸發(fā)一連串的view變化。

解決辦法

這種情況,開發(fā)者可以將所有對數(shù)據(jù)的操作獨立成一個數(shù)據(jù)層模塊,集中管理數(shù)據(jù)相關的action。
nej這種機制的例子(不討論緩存),delete操作作為理解例子util/cache/list.js
cache組件提供一個對外的action -- _$deleteItem

/**
 * 刪除列表項
 *
 * 腳本舉例
 * ```javascript
 * _cc._$deleteItem({
 *     key: "123"
 * });
 * ```
 *
 * @method   module:util/cache/list._$$CacheList#_$deleteItem
 * @param    {Object} arg0 - 配置信息
 * @property {String} key  - 列表標識
 * @property {String} id   - 列表項標識
 * @property {Object} data - 列表項數(shù)據(jù)信息
 * @property {Object} ext  - 需要回傳的數(shù)據(jù)信息
 * @return   {Void}
 */
_pro._$deleteItem = function(_options){
    _options = _u._$merge({},_options);
    _options.onload = this.__deleteItem._$bind(this,_options);
    this._$dispatchEvent("dodeleteitem",_options);
};

通過cache組件實例._$batEvent("dodeleteitem", function(){});來發(fā)送ajax請求。請求所要options由外部組件調用cache組件action時傳入。一般只需要傳入?yún)?shù)。onload回調使用dispatch事件(可以支持多個成功后的回調)。

/**
 * 刪除列表項回調
 *
 * @protected
 * @method module:util/cache/list._$$CacheList#__deleteItem
 * @param  {Object}  arg0 - 請求信息
 * @param  {Boolean} arg1 - 是否刪除成功
 * @return {Void}
 */
_pro.__deleteItem = function(_options,_isok){
    // 列表的例子中可以做一下cache相關的操作
    var _item,
        _key = _options.key;
    // sync memory
    if (!!_isok){
        var _id = _options.id;
        _item = this._$getItemInCache(_id)||null;
        this.__doRemoveItemFromList(_key,_id);
    }
    // callback
    var _event = {
        key:_key,
        data:_item,
        action:"delete",
        ext:_options.ext
    };
    this._$dispatchEvent("onitemdelete",_event);
    return _event;
};

通過cache組件實例._$batEvent("onitemdelete", function(){}); 可以實現(xiàn)刪除成功之后的回調。不同views組件可以獨立綁定事件回調,這樣代碼解耦。一個view不需要的時候,不需要改代碼。

每個cache組件都是一個單例實例。保證了在每個不同的功能組件(view)中用到的是同一個。
每一類list cache組件都可以有自己的不同的crud,例如bookList.js

// $$CacheList  == cache/list.js
var bookList = _t._$$CacheList._$allocate({
    id: "abc",
    doloadlist: function (_options) {
        // 從服務器加載列表
        _j._$request(
            "/api/list", {
                data: _options.data,
                onload: function (_list) {
                    _options.onload(_list);
                }
            }
        );
    },
    dodeleteitem: function (_options) {  _options由調用cache.action處傳入
        // 從服務器刪除數(shù)據(jù)項
        _j._$request(
            "/api/delete", {
                data: _options.data,
                onload: function (_item) {
                    _options.onload(_item);
                }
            }
        );
    }
});
return bookList;

nej對每一個list cache組件又抽象了一個基類cache/abstract.js
bookList.js繼承abstract.js,按照api實現(xiàn)指定接口,返回list cache組件實例
list的數(shù)據(jù)層管理,可以抽象出通用的api,crud。所以nej把這種場景抽象成list.js。實際生產(chǎn)中,如果模塊的數(shù)據(jù)層管理使用場景只有一個,也不需要在crud操作中做cache相關操作。一般只需要實例化成單例提供管理數(shù)據(jù)的action,dispatch相關事件到不同的views組件。

// custom.js
_p._$$Custom = _k._$klass(); 
_pro = _p._$$Custom._$extend(_t._$$EventTarget);
_pro.__doSendRequest = function(key,options){
    var conf = config[key];
    // onload event
    var onload = function(result){
        if (!result||(""+result.code).indexOf("2")!==0){
            onerror.call(this,result);
            return;
        }
        // callback
        var callback = options.onload||conf.onload||"success";
        if (u._$isFunction(callback)){
            callback.call(this,result.result);
        }else if(u._$isString(callback)){
            // dispatch在不同view組件中,綁定的事件
            this._$dispatchEvent(callback,result.result);
        }
    };
    // options其他屬性可以由調用action _$checkUserName處傳入
    //data
    //type:"json",
    //method:"POST",
    options.onload = onload._$bind(this);
    request(options)
};
_pro._$checkUserName = function(options){
    this.__doSendRequest("checkUserName", options);
};
return _p._$$Custom._$allocate({});

//在view組件中使用
// component1 
define(["custom.js"], function(c){
    c._$batEvent("onusernamecheckok", function(){
        console.log("表單中username相關驗證顯示通過的樣式");
    });
    // checkUserName DOM click事件
    var onCheck = function(
        c._$checkUserName({
            data: {xx: "王大錘"},
            onload: "onusernamecheckok"
        });
    );
});

// component2
define(["custom.js"], function(c){
    c._$batEvent("onusernamecheckok", function(){
        console.log("修改topbar的userName");
    });
});

如今mv**庫一片火熱的今天,也會也到多個view對應一個model的場景,facebook提出了一種解決方案單向數(shù)據(jù)流,單向數(shù)據(jù)流——就一個方向——當你需要插入新的數(shù)據(jù),流完全重新開始。他們把這種架構稱為Flux。

Flux的大致流程如下

通過這樣設計,View的功能就會變得純粹許多。它不需要關心組件的狀態(tài)和數(shù)據(jù)的操作,只需要把交到它們手中的數(shù)據(jù)渲染格式化成用戶能夠理解的輸出(HTML)。

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

轉載請注明本文地址:http://systransis.cn/yun/86083.html

相關文章

  • 關于框架

    摘要:事件訂閱發(fā)布者模式什么是讀音類似于是一套構建用戶界面的漸進式框架。與其他重量級框架不同的是,采用自底向上增量開發(fā)的設計。 MVC && MVVM 前端框架前端 MV*框架的意義 被誤解的MVC和被神化的MVVM Vue.js新手入門指南 單頁應用SPA的路由 單頁面應用的路由問題 本文是在自己總結時,看了許多篇文章有了些體會,然后把我認為有意義的摘抄下來,文中很大部分摘錄以上...

    Richard_Gao 評論0 收藏0
  • 切圖崽自我修養(yǎng)-[MVVM] Js MV*模式淺談

    摘要:在沒有環(huán)境下對進行單元測試的時候,應用邏輯正確性是無法驗證的更新的時候,無法對的更新操作進行斷言。對是通過接口進行,在對進行不依賴環(huán)境的單元測試的時候。這里根據(jù)上面的例子給出了的單元測試樣例。年微軟工程師在自己的博客上首次公布了模式。 前言 做客戶端開發(fā)、前端開發(fā)對MVC、MVP、MVVM這些名詞不了解也應該大致聽過,都是為了解決圖形界面應用程序復雜性管理問題而產(chǎn)生的應用架構模式。網(wǎng)上...

    bluesky 評論0 收藏0
  • 切圖崽自我修養(yǎng)-[MVVM] Js MV*模式淺談

    摘要:在沒有環(huán)境下對進行單元測試的時候,應用邏輯正確性是無法驗證的更新的時候,無法對的更新操作進行斷言。對是通過接口進行,在對進行不依賴環(huán)境的單元測試的時候。這里根據(jù)上面的例子給出了的單元測試樣例。年微軟工程師在自己的博客上首次公布了模式。 前言 做客戶端開發(fā)、前端開發(fā)對MVC、MVP、MVVM這些名詞不了解也應該大致聽過,都是為了解決圖形界面應用程序復雜性管理問題而產(chǎn)生的應用架構模式。網(wǎng)上...

    shleyZ 評論0 收藏0

發(fā)表評論

0條評論

tommego

|高級講師

TA的文章

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