消息

message.js

/**消息類悼凑,用來傳遞數(shù)據(jù)與方法 */

class Message {

? ? constructor() {

? ? ? ? if (!this.event_list) {

? ? ? ? ? ? this.event_list = {};

? ? ? ? }

? ? }

? ? static get Ins() {

? ? ? ? if (!this._ins)

? ? ? ? ? ? this._ins = new Message();

? ? ? ? return this._ins;

? ? }

? ? /**添加一個消息偵聽器 */

? ? on(eventName, content) {

? ? ? ? var _event, ctx;

? ? ? ? _event = this.event_list;

? ? ? ? //如果事件列表為空,就初始化

? ? ? ? if (!_event) {

? ? ? ? ? ? _event = this.event_list = {};

? ? ? ? } else {

? ? ? ? ? ? ctx = this.event_list[eventName];

? ? ? ? }

? ? ? ? //如果監(jiān)聽不存在璧瞬,就新建一個監(jiān)聽户辫,然后把監(jiān)聽器數(shù)量置為1

? ? ? ? if (!ctx) {

? ? ? ? ? ? ctx = this.event_list[eventName] = content;

? ? ? ? ? ? ctx.ListenerCount = 1;

? ? ? ? }

? ? ? ? //如果監(jiān)聽存在并且只有一個,就將監(jiān)聽賦值多個監(jiān)聽器的數(shù)組嗤锉,監(jiān)聽器數(shù)量為數(shù)組長度

? ? ? ? else if (typeof (ctx) == 'function') {

? ? ? ? ? ? ctx = this.event_list[eventName] = [ctx, content];

? ? ? ? ? ? ctx.ListenerCount = ctx.length;

? ? ? ? }

? ? ? ? //如果監(jiān)聽存在并且有多個渔欢,就直接push

? ? ? ? else if (Array.isArray(ctx)) {

? ? ? ? ? ? ctx.push(content);

? ? ? ? ? ? ctx.ListenerCount = ctx.length;

? ? ? ? }

? ? }

? ? /**派發(fā)一個消息 */

? ? emit(eventName) {

? ? ? ? try{

? ? ? ? ? ? var _event, ctx;

? ? ? ? ? ? //用slice方法將參數(shù)分離,第一個參數(shù)為監(jiān)聽器名稱瘟忱,后面的都會作為傳參使用

? ? ? ? ? ? var args = Array.prototype.slice.call(arguments, 1);

? ? ? ? ? ? // console.log(args)

? ? ? ? ? ? _event = this.event_list;

? ? ? ? ? ? if (_event) {

? ? ? ? ? ? ? ? ctx = this.event_list[eventName];

? ? ? ? ? ? }

? ? ? ? ? ? //如果沒有監(jiān)聽器奥额,就直接返回

? ? ? ? ? ? if (!ctx) {

? ? ? ? ? ? ? ? return false;

? ? ? ? ? ? }

? ? ? ? ? ? //如果監(jiān)聽器只有一個,直接apply觸發(fā)

? ? ? ? ? ? else if (typeof (ctx) == 'function') {

? ? ? ? ? ? ? ? ctx.apply(this, args);

? ? ? ? ? ? ? ? console.log(111,this)

? ? ? ? ? ? }

? ? ? ? ? ? //如果監(jiān)聽器有多個访诱,數(shù)組循環(huán)apply

? ? ? ? ? ? else if (Array.isArray(ctx)) {

? ? ? ? ? ? ? ? for (var i = 0; i < ctx.length; i++) {

? ? ? ? ? ? ? ? ? ? ctx[i].apply(this, args);

? ? ? ? ? ? ? ? ? ? console.log("=======",i,this)

? ? ? ? ? ? ? ? }

? ? ? ? ? ? }

? ? ? ? }catch(e){

? ? ? ? ? ? console.warn('發(fā)送消息有問題---》',e)

? ? ? ? }


? ? }

? ? /**刪除一個消息偵聽器 */

? ? remove(eventName, content) {

? ? ? ? var _event, ctx, index = 0;

? ? ? ? _event = this.event_list;

? ? ? ? if (!_event) {

? ? ? ? ? ? return this;

? ? ? ? } else {

? ? ? ? ? ? ctx = this.event_list[eventName];

? ? ? ? }

? ? ? ? if (!ctx) {

? ? ? ? ? ? return this;

? ? ? ? }

? ? ? ? if (typeof (ctx) == 'function') {

? ? ? ? ? ? if (ctx === content) {

? ? ? ? ? ? ? ? delete _event[eventName];

? ? ? ? ? ? }

? ? ? ? } else if (Array.isArray(ctx)) {

? ? ? ? ? ? for (var i = 0; i < ctx.length; i++) {

? ? ? ? ? ? ? ? if (ctx[i] === content) {

? ? ? ? ? ? ? ? ? ? this.event_list[eventName].splice(i - index, 1);

? ? ? ? ? ? ? ? ? ? ctx.ListenerCount = ctx.length;

? ? ? ? ? ? ? ? ? ? if (this.event_list[eventName].length === 0) {

? ? ? ? ? ? ? ? ? ? ? ? delete this.event_list[eventName]

? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? ? index++;

? ? ? ? ? ? ? ? }

? ? ? ? ? ? }

? ? ? ? }

? ? }

? ? /**刪除所有消息偵聽器 */

? ? removeAllListener(eventName) {

? ? ? ? var _event, ctx;

? ? ? ? _event = this.event_list;

? ? ? ? if (!_event) {

? ? ? ? ? ? return this;

? ? ? ? }

? ? ? ? ctx = this.event_list[eventName];

? ? ? ? if (arguments.length === 0 && (!eventName)) {

? ? ? ? ? ? var keys = Object.keys(this.event_list);

? ? ? ? ? ? for (var i = 0, key; i < keys.length; i++) {

? ? ? ? ? ? ? ? key = keys[i];

? ? ? ? ? ? ? ? delete this.event_list[key];

? ? ? ? ? ? }

? ? ? ? }

? ? ? ? if (ctx || typeof (ctx) == 'function' || Array.isArray(ctx)) {

? ? ? ? ? ? delete this.event_list[eventName];

? ? ? ? } else {

? ? ? ? ? ? return this;

? ? ? ? }

? ? }

}

const messageIns = Message.Ins;

export default messageIns;


msg.js

const msg = {

? ? elephantSay: 'elephantSay',? //大象說話

? ? changeGuideStep: 'changeGuideStep',? //修改新手引導(dǎo)階段

? ? uploadGuideStep: 'uploadGuideStep',? //上傳新手引導(dǎo)階段

? ? changePlantGuideState: 'changePlantGuideState',? ? //改變植物新手引導(dǎo)狀態(tài)

? ? changeProgress:"changeProgress",? ? //改變進度條

? ? changePage:"changePage",? // 改變頁面

? ? refreshHome:'refreshHome',

? ? elephantWatering: 'elephantChange',? // 改變大象svga

? ? showWaterTap: 'showWaterTap',? // 展示水龍頭

? ? refreshFriendsPage: 'refreshFriendsPage',? //刷新好友頁面

? ? refreshWaterDrop: 'refreshWaterDrop',? //刷新好友頁面我的水滴

}

export default msg;



使用

import messageIns from '../../utils/message'

import msg from '../../utils/msg'

//添加偵聽器

messageIns.on(msg.refreshHome,this.refreshHome.bind(this))

//派發(fā)一個消息

messageIns.emit(msg.refreshHome)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末垫挨,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子触菜,更是在濱河造成了極大的恐慌九榔,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異哲泊,居然都是意外死亡剩蟀,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門切威,熙熙樓的掌柜王于貴愁眉苦臉地迎上來育特,“玉大人,你說我怎么就攤上這事先朦$衷” “怎么了?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵烙无,是天一觀的道長锋谐。 經(jīng)常有香客問我,道長截酷,這世上最難降的妖魔是什么涮拗? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮迂苛,結(jié)果婚禮上三热,老公的妹妹穿的比我還像新娘。我一直安慰自己三幻,他們只是感情好就漾,可當(dāng)我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著念搬,像睡著了一般抑堡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上朗徊,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天首妖,我揣著相機與錄音,去河邊找鬼爷恳。 笑死,一個胖子當(dāng)著我的面吹牛温亲,可吹牛的內(nèi)容都是我干的棚壁。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼栈虚,長吁一口氣:“原來是場噩夢啊……” “哼袖外!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起魂务,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤在刺,失蹤者是張志新(化名)和其女友劉穎逆害,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蚣驼,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年相艇,在試婚紗的時候發(fā)現(xiàn)自己被綠了颖杏。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡坛芽,死狀恐怖留储,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情咙轩,我是刑警寧澤获讳,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站活喊,受9級特大地震影響丐膝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜钾菊,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一帅矗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧煞烫,春花似錦浑此、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至料饥,卻和暖如春蒲犬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背稀火。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工暖哨, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人凰狞。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓篇裁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親赡若。 傳聞我的和親對象是個殘疾皇子达布,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,914評論 2 355

推薦閱讀更多精彩內(nèi)容