第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

章節(jié)
問答
課簽
筆記
評論
占位
占位

場景切換

場景用頁面的切換都是在每個場景動作結束后自動切換到另一個場景。一般來說在代碼設計上盡量不要讓不相關的代碼耦合,所以場景之間盡量不要直接調用另外一個場景代碼。常規(guī)的來說,一般抽出到更上層通信了,提供一個統(tǒng)一的接口讓應用的不同部分進行通信

這里具體看下右邊代碼區(qū)域christmas.js中的代碼

頁面類pageA、pageB、pageC都提供一個完成的回調函數(shù),常規(guī)來說,因為有依賴所以就會有回調嵌套的問題。對了,可能想起來另一個解決方法 Deferred了,運用的思路其實差不多,但是這里更為直接的我引入了Observer模式

new pageA(function() {
    new pageB(function() {
        new pageC(function() {
            //執(zhí)行下一個
        })
    })
})

給每個場景對象訂閱一個"完成"的事件,然后在每個場景運行結束發(fā)派發(fā)這個"完成事件"

訂閱場景pageA完成事件

observer.subscribe("completeA", function() {
   //做一些是
})

觸發(fā)場景pageA完成事件

new pageA(function() {
    observer.publish("completeA"); //觸發(fā)
})

這里其實是一對一的關系,效果還不是很明顯,如果是對一多的關系,比如場景完成后,我們可以注冊很多的事件

總的來說,觀察者模式所做的工作就是在解耦,讓耦合的雙方都依賴于抽象,而不是依賴于具體。從而使得各自的變化都不會影響到另一邊的變化。

任務

christmas.js中,通過觀察者模式的處理,切面的切換都是通過事件通知。

請參考頁面A切換到頁面B的代碼,觸發(fā)B頁面的代碼

然后在代碼56行處填寫頁面B切換到頁面C的代碼,然后觸發(fā)pageC頁面

?不會了怎么辦

    observer.subscribe("completeB", function() {
        changePage($pageC, "effect-in", function() {
            observer.publish("pageC");
        })
    })

||

提問題

寫筆記

公開筆記
提交
||

請驗證,完成請求

由于請求次數(shù)過多,請先驗證,完成再次請求

加群二維碼

打開微信掃碼自動綁定

您還未綁定服務號

綁定后可得到

  • · 粉絲專屬優(yōu)惠福利
  • · 大咖直播交流干貨
  • · 課程更新,問題答復提醒
  • · 賬號支付安全提醒

收藏課程后,能更快找到我哦~

使用 Ctrl+D 可將課程添加到書簽

邀請您關注公眾號
關注后,及時獲悉本課程動態(tài)

舉報

0/150
提交
取消
全部 精華 我要發(fā)布
全部 我要發(fā)布
最熱 最新
只看我的

手記推薦

更多

本次提問將花費2個積分

你的積分不足,無法發(fā)表

為什么扣積分?

本次提問將花費2個積分

繼續(xù)發(fā)表請點擊 "確定"

為什么扣積分?