真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網站制作重慶分公司

在knockoutjs上自己實現的flux(實例講解)-創(chuàng)新互聯(lián)

在knockoutjs 上實現 Flux 單向數據流 狀態(tài)機,主要解決多個組件之間對數據的耦合問題。

我們提供的服務有:網站設計、成都網站建設、微信公眾號開發(fā)、網站優(yōu)化、網站認證、柳城ssl等。為上1000+企事業(yè)單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的柳城網站制作公司

一、其實簡單

flux的設計理念和實現方案,很大程度上人借鑒和參考了Vuex的實現,只是簡化了某些過程,數據流向圖如下:

在knockoutjs 上自己實現的flux(實例講解)

從上圖,中以看出數據的改變是單向循環(huán)的。我想這就是Flux理念的核心所在吧。Vuex中對Action規(guī)范為Action和Mutation,由action去觸發(fā)Mutation,action是可以異步的,而Mutation則是同步更新。而我在設計ko的Flux時,去掉了Mutation這個環(huán)節(jié),是因為我理解為,異步的請求一般情況下都是與api接口有關系,這塊內容存在極大的變化性,應該從業(yè)務或項目構架上做一層區(qū)分。

二、如果使用

當然,flux只是針對knockoutjs的,所以你使用之前必須引入knockoutjs。flux主要的方法和對象

2.1 靜態(tài)方法

方法 說明
flux.use 在require模式下,將flux與ko做關聯(lián)的方法,當然他必須先與createStore方法調用。
flux.createStore 創(chuàng)建一個store(狀態(tài)器)實例,當然此方法是有返回值,他的返回值可以調用register方法注冊到指定的域上,但第一次調用此方法時是創(chuàng)建rootStore(根狀態(tài)器),他不允許被注冊到域的。

2.1.1 flux.createStore參數格式

參數名稱 說明
state 狀態(tài)器相關狀態(tài)數據
actions 更改state上的狀態(tài)方法,方法的第一個參數為state,第二參數開始則為傳入的相關內容
getters 獲取state上的相關狀態(tài)數據,當然返回是一個ko監(jiān)控對象。

2.2 實例方法

createStore方法的執(zhí)行,會在ko實例上增加$store屬性,此屬性是狀態(tài)器的實例對象,在任何位置都可以調用他的dispatch來觸發(fā)事件。

方法 說明
register 創(chuàng)建和注冊一個狀態(tài)域,域與域之間是相互獨立存儲的,域之間action或get名稱是可以重復的
unRegister 移除一個狀態(tài)域
dispatch 根據actionName調用指定的action,無返回值
get 根據getName調用指定的get,有返回值

三、簡單的使用

本示例定義了四個ko綁定區(qū)域,分別是:app1, app2, app3, app4。實現app4中對name的改變自動影響到app1,而app3對列表的改變自動影響到app2。

在knockoutjs 上自己實現的flux(實例講解)

3.1 定義vm并初始化store

function ViewModel(){
 this.list = ko.observableArray();
 this.name = ko.observable('無名氏');
 this.count = ko.computed(function(){
  //必須用this,這個時候ko.$store還沒創(chuàng)建完成,應該ko.computed創(chuàng)建時會執(zhí)行一次此處
  //如果是子vm依賴主vm,還是可以用ko.$store的
  return this.list().length + '個數'; //需要對監(jiān)控對象求值,否則computed不能有效
 },this);
}
var fullVm = new ViewModel(); 
var index = 1;
fullVm.vf={
 add: function(){
  ko.$store.dispatch('addClass',{title: 'title' + (index++)});
 }
}
var opt = {
 state: {
  class: fullVm
 },
 actions:{
  "setName":function(state, name){
   state.class.name(name);
  },
  "addClass":function(state, classInfo){
   state.class.list.push(classInfo);
  }
 },
 getters:{
  "getName":function(state){
   return state.class.name;
  }
 }
}
flux.createStore(opt);

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


本文標題:在knockoutjs上自己實現的flux(實例講解)-創(chuàng)新互聯(lián)
標題網址:http://weahome.cn/article/dicddj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部