摘要:只需要返回對象本身就可以了。這里只實現(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
摘要:首先我們來講這個棧在中,每當有函數(shù)被執(zhí)行的時候都會在當前的執(zhí)行堆棧中創(chuàng)建一個新的堆棧幀,并放到棧頂。因為是鏈式調用,所以代碼一直在同一個作用于中執(zhí)行,也就是說當前的堆棧幀一直沒有被移出棧。 前言 前幾天在稀土上看到一篇面試的帖子,里面微信有一道題是lazyman的實現(xiàn),具體要做的事情就是 LazyMan(Hank) //Hi! This is Hank! LazyMan(Hank)....
摘要:前言之前在掘金上到一篇文章關于微信面試的文章,其中提到了手動實現(xiàn)的問題??雌饋砗孟裢τ腥さ?,我們來分析以下分析首先我們看到例子有幾個特點,一個是我們調用的時候不需要用到關鍵字,這意味著我們需要使用工廠函數(shù)另一個是要我們實現(xiàn)鏈式調用。 前言 之前在掘金上到一篇文章關于微信面試的文章,其中提到了手動實現(xiàn)Lazyman的問題。剛開始看到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...
摘要:實現(xiàn)一個,可以按照以下方式調用輸出輸出等待秒輸出輸出等待秒以此類推。這是典型的流程控制,問題的關鍵是如何實現(xiàn)任務的順序執(zhí)行。 實現(xiàn)一個LazyMan,可以按照以下方式調用: LazyMan(Hank)輸出: Hi! This is Hank! LazyMan(Hank).sleep(10).eat(dinner)輸出 Hi! This is H...
閱讀 4286·2021-09-26 10:11
閱讀 2678·2021-07-28 00:37
閱讀 3231·2019-08-29 15:29
閱讀 1193·2019-08-29 15:23
閱讀 3139·2019-08-26 18:37
閱讀 2474·2019-08-26 10:37
閱讀 606·2019-08-23 17:04
閱讀 2354·2019-08-23 13:44