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

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

在knockoutjs上自己實(shí)現(xiàn)的flux(實(shí)例講解)

在knockoutjs 上實(shí)現(xiàn) Flux 單向數(shù)據(jù)流 狀態(tài)機(jī),主要解決多個(gè)組件之間對(duì)數(shù)據(jù)的耦合問(wèn)題。

成都創(chuàng)新互聯(lián)專(zhuān)注于網(wǎng)站建設(shè),為客戶(hù)提供成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)開(kāi)發(fā)服務(wù),多年建網(wǎng)站服務(wù)經(jīng)驗(yàn),各類(lèi)網(wǎng)站都可以開(kāi)發(fā),高端網(wǎng)站設(shè)計(jì),公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設(shè)計(jì),建網(wǎng)站費(fèi)用,建網(wǎng)站多少錢(qián),價(jià)格優(yōu)惠,收費(fèi)合理。

一、其實(shí)簡(jiǎn)單

flux的設(shè)計(jì)理念和實(shí)現(xiàn)方案,很大程度上人借鑒和參考了Vuex的實(shí)現(xiàn),只是簡(jiǎn)化了某些過(guò)程,數(shù)據(jù)流向圖如下:

在knockoutjs 上自己實(shí)現(xiàn)的flux(實(shí)例講解)

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

二、如果使用

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

2.1 靜態(tài)方法

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

2.1.1 flux.createStore參數(shù)格式

參數(shù)名稱(chēng)說(shuō)明
state狀態(tài)器相關(guān)狀態(tài)數(shù)據(jù)
actions更改state上的狀態(tài)方法,方法的第一個(gè)參數(shù)為state,第二參數(shù)開(kāi)始則為傳入的相關(guān)內(nèi)容
getters獲取state上的相關(guān)狀態(tài)數(shù)據(jù),當(dāng)然返回是一個(gè)ko監(jiān)控對(duì)象。

2.2 實(shí)例方法

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

方法說(shuō)明
register創(chuàng)建和注冊(cè)一個(gè)狀態(tài)域,域與域之間是相互獨(dú)立存儲(chǔ)的,域之間action或get名稱(chēng)是可以重復(fù)的
unRegister移除一個(gè)狀態(tài)域
dispatch根據(jù)actionName調(diào)用指定的action,無(wú)返回值
get根據(jù)getName調(diào)用指定的get,有返回值

三、簡(jiǎn)單的使用

本示例定義了四個(gè)ko綁定區(qū)域,分別是:app1, app2, app3, app4。實(shí)現(xiàn)app4中對(duì)name的改變自動(dòng)影響到app1,而app3對(duì)列表的改變自動(dòng)影響到app2。

在knockoutjs 上自己實(shí)現(xiàn)的flux(實(shí)例講解)

3.1 定義vm并初始化store

function ViewModel(){
 this.list = ko.observableArray();
 this.name = ko.observable('無(wú)名氏');
 this.count = ko.computed(function(){
  //必須用this,這個(gè)時(shí)候ko.$store還沒(méi)創(chuàng)建完成,應(yīng)該ko.computed創(chuàng)建時(shí)會(huì)執(zhí)行一次此處
  //如果是子vm依賴(lài)主vm,還是可以用ko.$store的
  return this.list().length + '個(gè)數(shù)'; //需要對(duì)監(jiān)控對(duì)象求值,否則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);

根據(jù)上述代碼,首先定義了ViewModel的一個(gè)類(lèi),并創(chuàng)建了一個(gè)fullVm的一個(gè)實(shí)例,然后直接在fullVm實(shí)例上增加了add方法。

opt的state引用的是fullVm,其中還配置了actions和getters相關(guān)對(duì)象,然后調(diào)用flux.createStore(opt)方法。創(chuàng)建一個(gè)store,并關(guān)聯(lián)到ko.$store對(duì)象上。

3.2 與視圖綁定

html代碼:

app1:
app4:

app2:
app3:

js代碼:

var app1 = ko.applyBindings(fullVm, document.getElementById("app1"));
var app2 = ko.applyBindings(fullVm, document.getElementById("app2"));
var app3 = ko.applyBindings(fullVm, document.getElementById("app3"));
//測(cè)試兩個(gè)vm之間的依賴(lài) 解藕
var app4 = ko.applyBindings({
 name: ko.observable(),
 changeName:function(data,event){
  ko.$store.dispatch('setName', this.name());
 }
}, document.getElementById("app4"));

四、域的實(shí)例

html代碼:

js代碼:

function rootViewModel(){
 this.name = ko.observable('root'); 
}
var rVM = new rootViewModel();
flux.createStore({ state: rVM}); //創(chuàng)建root狀態(tài)器

var treeNode={
 name: ko.observable('node'),
 changeName:function(){
  ko.$store.areas.treeNode.state.name('新名字');
 },
 full: ko.computed(function(){
  //computed的職責(zé):1. 監(jiān)控其他對(duì)象屬性的變化,而影響自身對(duì)象(flux解決);2. 合并自身對(duì)象的幾個(gè)屬性(在function下,有this可解)
  //不能通過(guò)ko.$store訪問(wèn)對(duì)象本身,因?yàn)槭状螌?duì)象本身還沒(méi)初始化好
  var store = ko.$store;
  //(store.areas.treeNode? store.areas.treeNode.state.name() : '') 這樣也是不行,因?yàn)榻鉀Q第一次通不過(guò),后面肯定不行
  return store.state.name();
 })
}

ko.$store.register('treeNode', flux.createStore({ state: treeNode})); //創(chuàng)建子狀態(tài)機(jī)
var app1 = ko.applyBindings(rVM, document.getElementById("app1"));
var app2 = ko.applyBindings(treeNode, document.getElementById("app2"));

五、其他

當(dāng)然模塊化的引用,也是支持。具體實(shí)例細(xì)節(jié)可參考test中的測(cè)試示例。

項(xiàng)目的git地址:https://gitee.com/ko-plugins/flux.git,歡迎大家指正和提出寶貴的意見(jiàn)。

以上這篇在knockoutjs 上自己實(shí)現(xiàn)的flux(實(shí)例講解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持創(chuàng)新互聯(lián)。


名稱(chēng)欄目:在knockoutjs上自己實(shí)現(xiàn)的flux(實(shí)例講解)
分享網(wǎng)址:http://weahome.cn/article/pgdjsc.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部