av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 一道面試題,大家看過來

瀏覽:116日期:2022-12-28 13:46:19

問題描述

實現(xiàn)這樣子的函數(shù)

person(’tom’)// 輸出 hi tomperson(’tom’).getup(’洗刷刷’)// 輸出 hi tom// 輸出 tom getup and 洗刷刷person(’tom’).before(’噓噓’).getup(’洗刷刷’)// 輸出 tom 噓噓// 輸出 hi tom // 輸出 tom 噓噓 getup and 洗刷刷

問 用什么來實現(xiàn)??面試官說,涉及到異步,隊列什么的~~~

問題解答

回答1:

就是一個流程控制啊,就像lazyMan,可以看這個http://www.cnblogs.com/Upton/...

回答2:

我猜你要的是這個 下面展示一個原理 代碼結(jié)構(gòu)很簡單

有一個執(zhí)行隊列jobs 調(diào)用before的時候把內(nèi)容加到隊列頭部 調(diào)用getup的時候把內(nèi)容加到尾部

基本原理就是利用setTimeout 時間設(shè)置為0 setTimeout里面的函數(shù) 要在當(dāng)前運行環(huán)境所有東西運行完之后才會執(zhí)行

所以我在懷疑題主的第三個例子里 第三行又輸出一次噓噓 是不是筆誤

不過就算不是筆誤 也沒事 按照這個原理想怎么改就怎么改 多次調(diào)用也不是問題

function person(name){ var self = {}; self.jobs = ['hi ' + name]; self.before = function(s){self.jobs.unshift(name + ' ' + s);return this; } self.getup = function (s){self.jobs.push('getup and ' + s);return this; } setTimeout(function(){console.log(self.jobs)}, 0) return self;}

javascript - 一道面試題,大家看過來

回答3:

function person(name){ setTimeout(() => console.log(`hi ${name}`)); this.name = name; this.before = before_todo => {this.before_todo = before_todo; console.log(`${this.name} ${before_todo}`); return this; } this.getup = getup_todo => {setTimeout(() => { var str = this.name; if (this.before_todo) str += ’ ’ + this.before_todo; str += (’ getup and ’ + getup_todo); console.log(str); }); return this; } return this; }

javascript - 一道面試題,大家看過來

回答4:

參考 promise 實現(xiàn)過程

標(biāo)簽: JavaScript
主站蜘蛛池模板: 久久精品亚洲精品 | 精品综合 | 伊人网99 | 精品国产欧美一区二区 | 亚洲成a人片| 国产中文视频 | 一区二区三区免费 | 久久精品久久久久久 | 国产午夜精品久久久久免费视高清 | 精品免费国产 | www在线| 日韩中文一区 | 97超在线视频 | 自拍亚洲 | 精品二区 | 中文字幕在线观看一区 | 欧美日韩一 | 午夜99| 香蕉久久久 | 91av导航 | 国产成人免费网站 | 亚洲精品视频在线看 | 免费视频一区二区 | 亚洲免费视频播放 | 国产一区h | 伊人春色在线观看 | 久久久日韩精品一区二区三区 | 一区二区精品视频 | 精品亚洲一区二区三区 | 免费电影av | 在线视频 欧美日韩 | 久久专区| 成人免费一区二区三区牛牛 | 婷婷五月色综合 | 成人精品一区二区三区 | 超级黄色一级片 | 日本一区二区高清视频 | 在线中文字幕视频 | 在线播放91 | 中文字幕视频免费 | 最新日韩在线视频 |