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

資訊專欄INFORMATION COLUMN

LazyMan代碼實現(xiàn)

yhaolpz / 1512人閱讀

摘要:只需要返回對象本身就可以了。這里只實現(xiàn)一個示例實現(xiàn)鏈式調用從隊列頭部插入最后一步封裝還有一個大家可以來試一試。如果有想法的話歡迎提出大家交流一下

ES5實現(xiàn)LazyMan

lazyman主要原理是:

需要一個隊列保存將要用到的事件

利用閉包將事件保存至隊列中

創(chuàng)建一個中間件next用來觸發(fā)事件

鏈式調用

使用lazyman需要實現(xiàn)的場景:

LazyMan("Tom");
// my name is Tom!
LazyMan("Tom").eat("Pissa");
// my name is Tom!
// Eat Pissa ~
LazyMan("Tom").eat("Pissa").sleep(2);
// my name is Tom!
// Eat Pissa ~
// WakeUp after 2s !
LazyMan("Tom").wekeup(2).eat("Pissa");
// getup after 2s !
// my name is Tom
// Eat Pissa

核心代碼實現(xiàn):

需要創(chuàng)建一個數(shù)組當做隊列使用

function _LazyMan(name) {
    // 事件存儲隊列
    this.tasks = [];
    // 綁定this指向
    var _this = this;
    // 使用閉包
    var fn = (function(n) {
        // 綁定作用域
        var name = n;
        return function(name) {
            console.log("my name is "+ name);
            _this.next();
        }
    })(name);
    this.tasks.push(fn);
    // 啟動任務
    setTimeout(function() {
        _this.next();
    }, 0)
}

我們需要一個中間件next用來觸發(fā)事件

_LazyMan.prototype.next = function() {
    var fn = this.tasks.shift();
    fn && fn();
}

完成了觸發(fā)器、隊列存儲的位置,下一步只要實現(xiàn)鏈式調用就可以了。只需要返回this對象本身就可以了。
這里只實現(xiàn)一個wakeup示例

實現(xiàn)鏈式調用

_LazyMan.prototype.wakeup = function(times) {
    var _this = this;
    var fn = (function(time){
        return function() {
            setTimeout(function(){
                console.log("getup after "+time+"s !")
                _this.next();
            }, time*1000)
        }
    })(times)
    // 從隊列頭部插入
    _this.tasks.unshift(fn);
    return this;
}

最后一步封裝

function LazyMan(name) {
    return new _LazyMan(name)
}

還有一個sleep(), eat()大家可以來試一試。如果有想法的話歡迎提出~ 大家交流一下 O(∩_∩)O

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

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

相關文章

  • 關于lazyman你還應該知道這幾件事

    摘要:首先我們來講這個棧在中,每當有函數(shù)被執(zhí)行的時候都會在當前的執(zhí)行堆棧中創(chuàng)建一個新的堆棧幀,并放到棧頂。因為是鏈式調用,所以代碼一直在同一個作用于中執(zhí)行,也就是說當前的堆棧幀一直沒有被移出棧。 前言 前幾天在稀土上看到一篇面試的帖子,里面微信有一道題是lazyman的實現(xiàn),具體要做的事情就是 LazyMan(Hank) //Hi! This is Hank! LazyMan(Hank)....

    未東興 評論0 收藏0
  • LazyMan

    實現(xiàn)函數(shù)LazyMan,使得: LazyMan(Hank); 輸出Hi Hank! LazyMan(Hank).eat(dinner);輸出Hi Hank!Eat dinner! LazyMan(Hank).sleep(5).eat(dinner); 輸出Hi Hank!//等待五秒Eat dinner! LazyMan(Hank).sleepFirst(5).eat(dinner);輸出//等待...

    Winer 評論0 收藏0
  • 實現(xiàn)Lazyman

    摘要:前言之前在掘金上到一篇文章關于微信面試的文章,其中提到了手動實現(xiàn)的問題??雌饋砗孟裢τ腥さ?,我們來分析以下分析首先我們看到例子有幾個特點,一個是我們調用的時候不需要用到關鍵字,這意味著我們需要使用工廠函數(shù)另一個是要我們實現(xiàn)鏈式調用。 前言 之前在掘金上到一篇文章關于微信面試的文章,其中提到了手動實現(xiàn)Lazyman的問題。剛開始看到Lazyman我是一臉懵逼的,這是什么鬼,后來查了查了一...

    Tonny 評論0 收藏0
  • 如何實現(xiàn)一個 LazyMan?

    摘要:實現(xiàn)一個,可以按照以下方式調用輸出輸出等待秒輸出輸出等待秒以此類推。這是典型的流程控制,問題的關鍵是如何實現(xiàn)任務的順序執(zhí)行。 實現(xiàn)一個LazyMan,可以按照以下方式調用: LazyMan(Hank)輸出: Hi! This is Hank! LazyMan(Hank).sleep(10).eat(dinner)輸出 Hi! This is H...

    diabloneo 評論0 收藏0
  • 如何實現(xiàn)一個 LazyMan?

    摘要:實現(xiàn)一個,可以按照以下方式調用輸出輸出等待秒輸出輸出等待秒以此類推。這是典型的流程控制,問題的關鍵是如何實現(xiàn)任務的順序執(zhí)行。 實現(xiàn)一個LazyMan,可以按照以下方式調用: LazyMan(Hank)輸出: Hi! This is Hank! LazyMan(Hank).sleep(10).eat(dinner)輸出 Hi! This is H...

    frank_fun 評論0 收藏0

發(fā)表評論

0條評論

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