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

資訊專欄INFORMATION COLUMN

前端面試中的各種方法實現(xiàn)

funnyZhang / 2514人閱讀

摘要:如果對象的屬性值不為的時候,直接復(fù)制參數(shù)對象的每一個鍵值到新的對象對應(yīng)的鍵值對中。如果您覺得文章還不錯,請隨手點個贊,您的認同是我的動力

</>復(fù)制代碼

  1. 最近在面試,面試官動不動就讓寫一個原生方法的實現(xiàn),那咱們就在這里寫一下常見的一些實現(xiàn):
1.bind

</>復(fù)制代碼

  1. Function.prototype.bind2 = function (context) {
  2. var self = this;
  3. return function () {
  4. self.apply(context);
  5. }
  6. }
2.promise

</>復(fù)制代碼

  1. class Promise {
  2. result: any;
  3. callbacks = [];
  4. failbacks = [];
  5. constructor(fn) {
  6. fn(this.resolve.bind(this), this.reject.bind(this));
  7. }
  8. resolve(res) {
  9. if (this.callbacks.length > 0) this.callbacks.shift()(res, this.resolve.bind(this), this.reject.bind(this));
  10. }
  11. reject(res) {
  12. this.callbacks = [];
  13. if (this.failbacks.length > 0) this.failbacks.shift()(res, this.resolve.bind(this), this.reject.bind(this));
  14. }
  15. catch(fn) {
  16. this.failbacks.push(fn);
  17. }
  18. then(fn) {
  19. this.callbacks.push(fn);
  20. return this;
  21. }
  22. }
3.new的實現(xiàn)

</>復(fù)制代碼

  1. function create() {
  2. // 創(chuàng)建一個空的對象
  3. let obj = new Object()
  4. // 獲得構(gòu)造函數(shù)
  5. let Con = [].shift.call(arguments)
  6. // 鏈接到原型
  7. obj.__proto__ = Con.prototype
  8. // 綁定 this,執(zhí)行構(gòu)造函數(shù)
  9. let result = Con.apply(obj, arguments)
  10. // 確保 new 出來的是個對象
  11. return typeof result === "object" ? result : obj
  12. }
4.函數(shù)防抖

</>復(fù)制代碼

  1. // func是用戶傳入需要防抖的函數(shù)
  2. // wait是等待時間
  3. const debounce = (func, wait = 50) => {
  4. // 緩存一個定時器id
  5. let timer = 0
  6. // 這里返回的函數(shù)是每次用戶實際調(diào)用的防抖函數(shù)
  7. // 如果已經(jīng)設(shè)定過定時器了就清空上一次的定時器
  8. // 開始一個新的定時器,延遲執(zhí)行用戶傳入的方法
  9. return function(...args) {
  10. if (timer) clearTimeout(timer)
  11. timer = setTimeout(() => {
  12. func.apply(this, args)
  13. }, wait)
  14. }
  15. }
5.函數(shù)節(jié)流

</>復(fù)制代碼

  1. function throttle(method,delay){
  2. var timer=null;
  3. return function(){
  4. var context=this, args=arguments;
  5. clearTimeout(timer);
  6. timer=setTimeout(function(){
  7. method.apply(context,args);
  8. },delay);
  9. }
  10. }
6.深拷貝

</>復(fù)制代碼

  1. function deepClone(obj) {
  2. let result = typeof obj.splice === "function" ? [] : {};
  3. if (obj && typeof obj === "object") {
  4. for (let key in obj) {
  5. if (obj[key] && typeof obj[key] === "object") {
  6. result[key] = deepClone(obj[key]);//如果對象的屬性值為object的時候,遞歸調(diào)用deepClone,即在吧某個值對象復(fù)制一份到新的對象的對應(yīng)值中。
  7. } else {
  8. result[key] = obj[key];//如果對象的屬性值不為object的時候,直接復(fù)制參數(shù)對象的每一個鍵值到新的對象對應(yīng)的鍵值對中。
  9. }
  10. }
  11. return result;
  12. }
  13. return obj;
  14. }
7.extends實現(xiàn)

</>復(fù)制代碼

  1. //子類 extends 父類
  2. Function.prototype.extends = function(func, options){
  3. for(var key in func.prototype){
  4. this.prototype[key] = func.prototype[key];
  5. }
  6. for(var name in options){
  7. this.prototype[name] = options[name];
  8. }
  9. }
8.單例模式

</>復(fù)制代碼

  1. function A(name){
  2. // 如果已存在對應(yīng)的實例
  3. if(typeof A.instance === "object"){
  4. return A.instance
  5. }
  6. //否則正常創(chuàng)建實例
  7. this.name = name
  8. // 緩存
  9. A.instance =this
  10. return this
  11. }
9.發(fā)布訂閱模式

</>復(fù)制代碼

  1. // 事件類
  2. class EventEmitter {
  3. constructor () {
  4. this.events = { } // 事件隊列,保存著每一種事件的處理程序
  5. }
  6. on (type, callback) { // type 要綁定的事件名字, callback 處理程序
  7. if (this.events[type]) {// 如果事件隊列中有這個事件
  8. // 將此次綁定的處理程序放入進去
  9. this.events[type].push(callback.bind(this))
  10. return false
  11. }
  12. // 如果沒有這個事件,新建
  13. this.events[type] = [callback.bind(this)]
  14. }
  15. emit (type, ...args) {
  16. // 觸發(fā)事件的時候如果沒有事件,報錯
  17. if (!this.events[type]) {
  18. console.error("type event is not found")
  19. }else {
  20. // 挨個執(zhí)行隊列中的處理程序
  21. this.events[type].forEach(callback => {
  22. callback(...args)
  23. });
  24. }
  25. }
  26. }
  27. let bus = new EventEmitter()
  28. bus.on("play", (num1, num2) => {
  29. alert(123)
  30. })
  31. bus.on("play", (num1, num2) => {
  32. alert(456)
  33. alert(num1 + num2)
  34. })
  35. bus.emit("play", 1, 2)
總結(jié)

以上是面試過程中常見的方法實現(xiàn),只是簡單的實現(xiàn),面試的各位可以看下準(zhǔn)備下。
如果您覺得文章還不錯,請隨手點個贊,您的認同是我的動力!

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

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/100568.html

相關(guān)文章

  • 前端秋招面試總結(jié)

    摘要:前言秋招宣告結(jié)束,面試了接近家公司,有幸拿到,感謝這段時間一起找工作面試的朋友和陪伴我的人。一定要提前準(zhǔn)備好,不然面試官叫你說遇到的難點,或者直接問問題時可能會懵逼。 前言 秋招宣告結(jié)束,面試了接近20家公司,有幸拿到offer,感謝這段時間一起找工作面試的朋友和陪伴我的人。這是一段難忘的經(jīng)歷,相信不亞于當(dāng)年的高考吧,也許現(xiàn)在想起來高考不算什么,也許只有經(jīng)歷過秋招的人才懂得找工作的艱辛...

    Gu_Yan 評論0 收藏0
  • 前端秋招面試總結(jié)

    摘要:前言秋招宣告結(jié)束,面試了接近家公司,有幸拿到,感謝這段時間一起找工作面試的朋友和陪伴我的人。一定要提前準(zhǔn)備好,不然面試官叫你說遇到的難點,或者直接問問題時可能會懵逼。 前言 秋招宣告結(jié)束,面試了接近20家公司,有幸拿到offer,感謝這段時間一起找工作面試的朋友和陪伴我的人。這是一段難忘的經(jīng)歷,相信不亞于當(dāng)年的高考吧,也許現(xiàn)在想起來高考不算什么,也許只有經(jīng)歷過秋招的人才懂得找工作的艱辛...

    Scholer 評論0 收藏0
  • 前端面試總結(jié)(at, md)

    摘要:面試官比較著急了,跟我溝通的時候,我才知道返回值不一定非要跟原生的一樣。騰訊一面平常開發(fā)怎么設(shè)計組件的??偨Y(jié)騰訊面試的感覺就是,沒有那么正式,都是部門的技術(shù)直接聯(lián)系的你,然后二面就是部門負責(zé)人了,決定了是否入職。 引入 面試過去了這么久,把八月份面試題和總結(jié)發(fā)一下吧,雖然年底大家可能都不換工作~ 還是可以看看的。 關(guān)于面試,引用葉老濕的一句話。你的簡歷是自己工作的答卷,項目經(jīng)歷是你給面...

    zhunjiee 評論0 收藏0
  • java面試總結(jié)

    摘要:面試總結(jié)因為我是開發(fā),所以面試的都是后端開發(fā),只能總結(jié)一些這方面的題。因為我也沒有面試太多的公司,在小城市,沒有太多的大公司,所以總結(jié)的只有這些,希望想要換工作的人,提前準(zhǔn)備。 好久沒有更新文章了,不是因為偷懶,是因為忙著準(zhǔn)備面試了,現(xiàn)在總結(jié)下最近的面試心得,希望對大家有幫助 時刻準(zhǔn)備著 每次入職一個公司,我們都是想著一直干下去的,但是這只不過是我們的一廂情愿罷了,工作中有太多的不可控...

    Lionad-Morotar 評論0 收藏0
  • JavaScript系列(四) - 收藏集 - 掘金

    摘要:函數(shù)式編程前端掘金引言面向?qū)ο缶幊桃恢币詠矶际侵械闹鲗?dǎo)范式。函數(shù)式編程是一種強調(diào)減少對程序外部狀態(tài)產(chǎn)生改變的方式。 JavaScript 函數(shù)式編程 - 前端 - 掘金引言 面向?qū)ο缶幊桃恢币詠矶际荍avaScript中的主導(dǎo)范式。JavaScript作為一門多范式編程語言,然而,近幾年,函數(shù)式編程越來越多得受到開發(fā)者的青睞。函數(shù)式編程是一種強調(diào)減少對程序外部狀態(tài)產(chǎn)生改變的方式。因此,...

    cfanr 評論0 收藏0

發(fā)表評論

0條評論

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