精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JavaScript:面試頻繁出現的幾個易錯點

開發 前端
這段時間,金三銀四,很多人面試,很多人分享面試題。在前段時間,我也臨時擔任面試官,為了大概了解面試者的水平,我也寫了一份題目,面試了幾個前端開發者。在這段時間里面,我在學,在寫設計模式的一些知識,想不到的設計模式的這些知識,就是面試題里面,頻繁讓人掉坑的考點。所以,今天就總結一下,那些讓人掉坑的考點。

[[224950]]

1.前言

這段時間,金三銀四,很多人面試,很多人分享面試題。在前段時間,我也臨時擔任面試官,為了大概了解面試者的水平,我也寫了一份題目,面試了幾個前端開發者。在這段時間里面,我在學,在寫設計模式的一些知識,想不到的設計模式的這些知識,就是面試題里面,頻繁讓人掉坑的考點。所以,今天就總結一下,那些讓人掉坑的考點。

2.面向對象編程

關于面向對象和面向過程,個人覺得這兩者不是絕對獨立的,而是相互相成的關系。至于什么時候用面向對象,什么時候用面向過程,具體情況,具體分析。

針對于面向對象編程的。知乎上有一個高贊回答:

面向對象: 狗.吃(屎)

面向過程: 吃.(狗,屎)

但是這個例子覺得不太優雅,我改一下了,舉一個優雅些的小例子說明一下面向對象和面向過程的區別。

需求:定義‘守候吃火鍋’

面向對象的思想是:守候.動作(吃火鍋)

面向過程的思想是:動作(守候,吃火鍋)

代碼實現方面:

 

  1. //面向對象  
  2. //定義人(姓名)  
  3. let People=function(name){  
  4.     this.name=name 
  5.  
  6. //動作  
  7. People.prototype={  
  8.     eat:function(someThing){  
  9.         console.log(`${this.name}吃${someThing}`);  
  10.     }  
  11.  
  12. //守候是個人,所以要創建一個人(new一次People)  
  13. let shouhou=new People('守候','男',24);  
  14. shouhou.eat('火鍋');  
  15.  
  16. //面向過程  
  17. let eat=function(who,someThing){  
  18.     console.log(`${who}吃${someThing}`);  
  19.  
  20. eat('守候','火鍋'); 

結果都一樣,都是輸出‘守候吃火鍋’。但是萬一我現在吃飽了,準備寫代碼了。這下怎么實現呢?看代碼

 

  1. //面向對象  
  2. shouhou.coding=function(){  
  3.     console.log(this.name+'寫代碼');  
  4.  
  5. shouhou.coding();  
  6. //面向過程  
  7. let coding=function(who){  
  8.     console.log(who+'寫代碼');  
  9.  
  10. coding('守候'); 

結果也一樣:‘守候寫代碼’

但是不難發現面向對象更加的靈活,復用性和擴展性更加。因為面向對象就是針對對象(例子中的:‘守候’)來進行執行某些動作。這些動作可以自定義擴展。

而面向過程是定義很多的動作,來指定誰來執行這個動作。

好了,面向對象的簡單說明就到這里了,至于面向對象的三大特性:繼承,封裝,多態這個自行上網查找資料。

3.this

使用 JavaScript 開發的時候,很多開發者多多少少會被 this 的指向搞蒙圈,但是實際上,關于 this 的指向,記住最核心的一句話:哪個對象調用函數,函數里面的this指向哪個對象。

下面分幾種情況談論下

3-1.普通函數調用

這個情況沒特殊意外,就是指向全局對象-window。

 

  1. let username='守候'  
  2. function fn(){  
  3.     alert(this.username);//undefined  
  4.  
  5. fn(); 

可能大家會困惑,為什么不是輸出守候,但是在細看一看,我聲明的方式是let,不會是window對象

如果輸出守候,要這樣寫

 

  1. var username='守候'  
  2. function fn(){  
  3.     alert(this.username);//守候  
  4.  
  5. fn();  
  6. //---------------  
  7. window.username='守候'  
  8. function fn(){  
  9.     alert(this.username);//守候  
  10.  
  11. fn(); 

3-2.對象函數調用

這個相信不難理解,就是那個函數調用,this指向哪里

 

  1. window.b=2222 
  2.  
  3. let obj={ 
  4.  
  5.     a:111, 
  6.  
  7.     fn:function(){ 
  8.  
  9.         alert(this.a);//111 
  10.  
  11.         alert(this.b);//undefined 
  12.  
  13.     } 
  14.  
  15.  
  16. obj.fn(); 

很明顯,第一次就是輸出obj.a,就是111。而第二次,obj沒有b這個屬性,所以輸出undefined,因為this指向obj。

但是下面這個情況得注意

 

  1. let obj1={  
  2.     a:222  
  3. };  
  4. let obj2={  
  5.     a:111,  
  6.     fn:function(){  
  7.         alert(this.a);  
  8.     }  
  9.  
  10. obj1.fn=obj2.fn;  
  11. obj1.fn();//222 

這個相信也不難理解,雖然obj1.fn是從obj2.fn賦值而來,但是調用函數的是obj1,所以this指向obj1。

3-3.構造函數調用

 

  1. let TestClass=function(){  
  2.     this.name='111' 
  3.  
  4. let subClass=new TestClass();  
  5. subClass.name='守候' 
  6. console.log(subClass.name);//守候  
  7. let subClass1=new TestClass();  
  8. console.log(subClass1.name)//111 

這個也是不難理解,回憶下(new的四個步驟)就差不多了!

但是有一個坑,雖然一般不會出現,但是有必要提一下。

在構造函數里面返回一個對象,會直接返回這個對象,而不是執行構造函數后創建的對象

3-4.apply和call調用

apply和call簡單來說就是會改變傳入函數的this。

 

  1. let obj1={  
  2.     a:222  
  3. };  
  4. let obj2={  
  5.     a:111,  
  6.     fn:function(){  
  7.         alert(this.a);  
  8.     }  
  9.  
  10. obj2.fn.call(obj1); 

此時雖然是 obj2 調用方法,但是使用 了call,動態的把 this 指向到 obj1。相當于這個 obj2.fn 這個執行環境是 obj1 。apply 和 call 詳細內容在下面提及。

3-5.箭頭函數調用

首先不得不說,ES6 提供了箭頭函數,增加了我們的開發效率,但是在箭頭函數里面,沒有 this ,箭頭函數里面的 this 是繼承外面的環境。

一個例子

 

  1. let obj={  
  2.     a:222,  
  3.     fn:function(){   
  4.         setTimeout(function(){console.log(this.a)})  
  5.     }  
  6. };  
  7. obj.fn();//undefined 

不難發現,雖然 fn() 里面的 this 是指向 obj ,但是,傳給 setTimeout 的是普通函數, this 指向是 window , window 下面沒有 a ,所以這里輸出 undefined 。

換成箭頭函數

 

  1. let obj={  
  2.     a:222,  
  3.     fn:function(){   
  4.         setTimeout(()=>{console.log(this.a)});  
  5.     }  
  6. };  
  7. obj.fn();//222 

這次輸出 222 是因為,傳給 setTimeout 的是箭頭函數,然后箭頭函數里面沒有 this ,所以要向上層作用域查找,在這個例子上, setTimeout 的上層作用域是 fn。而 fn 里面的 this 指向 obj ,所以 setTimeout 里面的箭頭函數的 this ,指向 obj 。所以輸出 222 。

4.call和apply

call 和 apply 的作用,完全一樣,唯一的區別就是在參數上面。

call 接收的參數不固定,第一個參數是函數體內 this 的指向,第二個參數以下是依次傳入的參數。

apply接收兩個參數,第一個參數也是函數體內 this 的指向。第二個參數是一個集合對象(數組或者類數組)

 

  1. let fn=function(a,b,c){  
  2. console.log(a,b,c);  
  3.  
  4. let arr=[1,2,3]; 

如上面這個例子

 

  1. let obj1={  
  2.     a:222  
  3. };  
  4. let obj2={  
  5.     a:111,  
  6.     fn:function(){  
  7.         alert(this.a);  
  8.     }  
  9.  
  10. obj2.fn.call(obj1); 

call 和 apply 兩個主要用途就是

1.改變 this 的指向(把 this 從 obj2 指向到 obj1 )

2.方法借用( obj1 沒有 fn ,只是借用 obj2 方法)

5.閉包

閉包這個可能大家是迷糊,但是必須要征服的概念!下面用一個例子簡單說下

 

  1. let add=(function(){  
  2. let now=0;  
  3. return {  
  4.  doAdd:function(){  
  5.     now++;  
  6.     console.log(now);  
  7.  
  8.  
  9. })() 

然后執行幾次!

上圖結果看到,now 這個變量,并沒有隨著函數的執行完畢而被回收,而是繼續保存在內存里面。

具體原因說下:剛開始進來,因為是自動執行函數,一開始進來會自動執行,這一塊

然后把這個對象賦值給 add 。由于 add 里面有函數是依賴于 now 這個變量。所以 now 不會被銷毀,回收。這就是閉包的用途之一(延續變量周期)。由于 now 在外面訪問不到,這就是閉包的另一個用途(創建局部變量,保護局部變量不會被訪問和修改)。

可能有人會有疑問,閉包會造成內存泄漏。但是大家想下,上面的例子,如果不用閉包,就要用全局變量。把變量放在閉包里面和放在全局變量里面,影響是一致的。使用閉包又可以減少全局變量,所以上面的例子閉包更好!

6.小結

 

在學設計模式的時候,遇到的知識點就是這一些了,這些知識點,也是我在群聊,社區里面,讓人掉坑比較多的考點。這些知識,可以說是開發常用,面試常考的知識,還是建議大家深入些學習。上面那里也是簡單的過一下而已。不算深入。如果大家對文章有什么建議,歡迎指點。 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2016-12-06 10:52:07

JavaScript易錯知識點

2023-12-04 16:15:05

Docker容器

2022-05-09 07:08:14

LinuxBashShell

2025-04-10 11:00:00

Python編程開發

2022-08-01 10:11:24

Bash編程易錯代碼

2021-07-30 06:08:04

C++字節對齊自然對齊

2015-06-02 11:30:59

面試技術面試

2019-08-28 18:24:13

SaaS云計算企業

2016-12-21 09:55:55

面試JavaScrip總結

2022-08-03 08:03:03

前端APIjavascript

2010-04-07 09:21:03

Oracle RAC

2021-05-11 20:31:46

Stringnull

2021-09-22 11:06:50

易點云

2010-05-27 11:10:12

MySQL4.1

2010-07-15 09:54:04

2010-07-05 14:11:07

SQL Server

2009-10-13 14:33:00

2023-01-29 08:04:24

線程池非核心線程任務

2010-05-11 13:25:18

Mysql大小寫

2020-07-02 15:15:22

JavaScript面試前端
點贊
收藏

51CTO技術棧公眾號

国产日韩欧美精品| 久久精品亚洲94久久精品| 免费在线看黄色片| 午夜福利一区二区三区| 日韩中文字幕麻豆| 日韩最新免费不卡| 国产精品亚洲一区二区无码| 亚洲最大网站| 国产精品成人免费| 精品奇米国产一区二区三区| 婷婷五月综合缴情在线视频| 国产三级视频在线| 国产一区二区在线视频| 性欧美长视频免费观看不卡| 91在线无精精品白丝| 成人97精品毛片免费看| 精品久久中文字幕久久av| 午夜精品福利一区二区| 亚洲免费视频网| 美女在线观看视频一区二区| 91禁外国网站| 成年人二级毛片| 免费看成人哺乳视频网站| 正在播放一区二区| caopor在线视频| 国产精品186在线观看在线播放| 国产午夜亚洲精品不卡| 成人在线视频网址| 中文字字幕在线观看| 亚洲日韩视频| 欧美超级免费视 在线| 精品日韩在线视频| 亚洲精品推荐| 亚洲国产精品va| gogo亚洲国模私拍人体| 国产精品黄色片| 色综合久久88色综合天天免费| 热久久最新网址| 日本高清在线观看wwwww色| 久久精品夜色噜噜亚洲aⅴ| 99re资源| 亚洲av无码乱码国产精品| 青青青伊人色综合久久| 秋霞成人午夜鲁丝一区二区三区| 亚洲一区欧美在线| 欧美色图首页| 欧美人交a欧美精品| 在线观看亚洲网站| 久久久久久久久久久9不雅视频| 国产视频欧美视频| 免费看黄色aaaaaa 片| 成人午夜大片| 欧美精品一区二| 亚洲天堂小视频| 精品一区二区三区在线观看视频| 精品视频一区三区九区| 欧美性猛交久久久乱大交小说 | 中文字幕亚洲第一| 成都免费高清电影| 国产91久久精品一区二区| 亚洲精品一区av在线播放| 右手影院亚洲欧美| 奇米亚洲欧美| 中文字幕亚洲欧美日韩高清| 国产精品理论在线| 91九色精品| 欧美老女人在线视频| 国产黄色片在线免费观看| 欧美久久综合| 国产69久久精品成人| 欧美黑人一区二区| 日韩成人一级片| 国产日本欧美在线观看| 97人妻精品一区二区三区| 国产在线一区观看| 超碰97人人人人人蜜桃| 欧洲精品久久一区二区| xfplay精品久久| 茄子视频成人在线观看| 在线观看a视频| 亚洲精品免费视频| 精品欧美一区二区在线观看视频 | 在线免费观看av网址| 亚洲欧美不卡| 国产精品一区二区女厕厕| 99国产精品99| 91亚洲精品乱码久久久久久蜜桃| 日本中文不卡| 影音先锋在线视频| 黑人巨大精品欧美一区二区一视频| 妞干网在线免费视频| 亚洲人体在线| 亚洲国产女人aaa毛片在线| 无码一区二区三区在线| 精品一区二区三区视频在线播放| 欧美不卡视频一区| 男女做爰猛烈刺激| 亚洲国产不卡| 国产91精品久久久久久久| 一级特黄aaa大片在线观看| 成人性生交大片免费| 青青草原亚洲| 牛牛精品在线视频| 欧美亚洲自拍偷拍| 国产av一区二区三区传媒| 国产精品一区2区3区| 久久成人亚洲精品| 制服.丝袜.亚洲.中文.综合懂色| 久久99热这里只有精品| 精品一卡二卡三卡四卡日本乱码| 免费成人黄色| 日韩欧美在线视频观看| 国产九九九视频| 久久av导航| 欧美黑人一级爽快片淫片高清| 丁香社区五月天| 国产成都精品91一区二区三| 亚洲成人网上| 日韩伦理精品| 精品成人在线观看| 五月天免费网站| 免费永久网站黄欧美| 成人av中文| 韩国中文字幕在线| 欧洲一区在线观看| 国产特黄级aaaaa片免| 黄色精品网站| 91久热免费在线视频| 高清在线观看av| 天天做天天摸天天爽国产一区 | 成人国产精品视频| 久久最新免费视频| 51一区二区三区| 亚洲精品视频中文字幕| 日韩精品视频免费看| 国产毛片精品视频| 中国成人在线视频| 香蕉成人在线| 中文字幕免费精品一区高清| 成年人晚上看的视频| 91免费视频网| 六月丁香激情网| 久久97精品| 国模私拍视频一区| 欧美一区二区在线观看视频| 亚洲国产视频网站| 深夜视频在线观看| 欧美深夜福利| 国产精品白丝jk白祙| 欧美另类tv| 精品久久久久久最新网址| 欧美丰满艳妇bbwbbw| 国产乱码精品一区二区三区av| 公共露出暴露狂另类av| 亚洲欧洲日韩精品在线| 久久伊人精品天天| 精品黑人一区二区三区国语馆| 日韩毛片视频在线看| 天天av天天操| 欧美韩国一区| www.一区二区三区| wwww亚洲| 亚洲精品720p| 黄瓜视频在线免费观看| 欧美激情中文字幕一区二区| 日韩av片网站| 91精品国产调教在线观看| 亚洲直播在线一区| av资源中文在线| 日韩精品视频在线观看网址| 中文字幕免费观看| 国产精品毛片a∨一区二区三区| 粉色视频免费看| 亚洲国产老妈| 国模精品一区二区三区| 日本韩国欧美| 久久精品成人欧美大片| 欧美 日韩 人妻 高清 中文| 天天综合日日夜夜精品| 高潮毛片无遮挡| 蜜桃视频免费观看一区| 老司机午夜免费福利视频| 欧美电影在线观看免费| 国产精品福利网站| a级片国产精品自在拍在线播放| 精品国产三级电影在线观看| www.久久精品视频| 国产精品的网站| 亚洲麻豆一区二区三区| 视频一区欧美精品| 国产精品自拍合集| 精品国产一区二区三区| 亚洲最大的免费| 亚洲精品福利电影| 久久精品小视频| 日韩电影在线观看完整版| 欧美精品日日鲁夜夜添| 99免费在线观看| 中文字幕va一区二区三区| 肉丝美足丝袜一区二区三区四| 亚洲一区久久| 综合一区中文字幕| 一本色道久久综合亚洲精品酒店| 亚洲资源在线看| 日韩电影大全网站| 久久久在线视频| 九七久久人人| 国产一级揄自揄精品视频| 亚洲成人中文字幕在线| 欧美日韩在线精品一区二区三区激情| 精品无码av在线| 国产精品久久久久久久久快鸭| japanese在线观看| 国产精品一区二区久激情瑜伽| 日本在线视频www| 亚洲二区视频| 免费的一级黄色片| 久久一区二区中文字幕| 欧美激情专区| 欧美大胆视频| 国产精品免费一区二区三区四区 | 久久三级福利| 97超碰在线人人| 伊人久久大香线| 亚洲巨乳在线观看| 免费成人av| 精品一区二区三区日本| 一区二区免费| 91久久精品一区二区别| 亚洲欧美在线人成swag| 国产精品九九九| 在线手机中文字幕| 97精品一区二区三区| 欧美激情成人动漫| 欧美裸身视频免费观看| 黄色av网站在线播放| 日韩中文字幕国产精品| 国产精品一二三区视频| 亚洲欧美在线看| 日本中文字幕电影在线观看| 亚洲成人久久久久| 丰满人妻一区二区三区四区53 | 91香蕉国产在线观看| 黄色成人在线观看网站| 国产精品久久久久久一区二区 | 亚洲影院污污.| 国产在线一区不卡| 亚洲一区二区三区成人在线视频精品| 亚洲ww精品| 成人久久久久久| 成人免费91| 成人动漫视频在线观看完整版| 一区二区三区四区精品视频| 成人性色av| 嫩草国产精品入口| 麻豆av一区二区三区| 曰本一区二区三区视频| 欧美日韩另类综合| 日本不卡电影| 99精品视频网站| 国产精品v亚洲精品v日韩精品| 国产xxxx振车| 羞羞答答国产精品www一本| 国产裸体免费无遮挡| 美女www一区二区| 视频免费1区二区三区| 国产精品99久| 成年人的黄色片| 国产亚洲美州欧州综合国| 国产三级aaa| 亚洲蜜桃精久久久久久久| 国产一级av毛片| 欧美色xxxx| 艳妇乳肉豪妇荡乳av| 欧美一区二区三区视频免费播放| 亚洲乱码在线观看| 日韩精品高清在线| 午夜在线小视频| 欧美片一区二区三区| sis001欧美| 国产精品丝袜久久久久久不卡| 国产一区二区在线观| 精品国产综合区久久久久久| 大色综合视频网站在线播放| 五月天激情图片| 久久精品在线| 无码人妻aⅴ一区二区三区玉蒲团| 国产亚洲精品资源在线26u| 欧美色图亚洲视频| 在线欧美日韩国产| 亚洲AV无码精品国产| 尤物99国产成人精品视频 | 日本中文字幕久久看| 亚洲国产天堂| 久久伊人资源站| 你懂的国产精品| www.欧美日本| 99re热这里只有精品视频| 精品亚洲乱码一区二区| 黑人巨大精品欧美一区二区一视频 | 国产精品一区二区av| 成人同人动漫免费观看| 黄色一级视频在线播放| 国产一区视频网站| 久久久久无码精品国产sm果冻| 夜夜嗨av一区二区三区中文字幕| 无码人妻av免费一区二区三区| 日韩亚洲欧美在线观看| av中文资源在线| 97超视频免费观看| 亚洲精品在线播放| 伊人婷婷久久| 日韩高清不卡一区二区| 亚洲中文字幕一区| 日韩毛片精品高清免费| 中文字幕手机在线视频| 精品久久一区二区三区| 尤物网在线观看| 国产精品久久久久久久久久东京 | 日本中文字幕不卡| 午夜精品中文字幕| 欧美国产日韩精品免费观看| 国产大片中文字幕| 日韩视频在线一区二区| 国产高清免费在线播放| 久久久免费精品| 日本成人精品| 午夜精品亚洲一区二区三区嫩草| 久久精品一区| 午夜一区二区三区免费| 亚洲天堂2016| 99产精品成人啪免费网站| 中文字幕日韩欧美| 99久久精品一区二区成人| 久久99精品国产99久久| 亚洲激情中文在线| 久久这里只精品| 国产欧美日韩卡一| 毛片在线免费播放| 亚洲人成五月天| 国产高清不卡| 国产一区福利视频| 香蕉国产精品| 91免费视频污| 亚洲老妇xxxxxx| 亚洲精品成人电影| 欧美老肥婆性猛交视频| 1204国产成人精品视频| 穿情趣内衣被c到高潮视频| 免费成人在线观看| 青青草华人在线视频| 国产日本亚洲高清| 夜夜爽妓女8888视频免费观看| 日韩成人性视频| 第一中文字幕在线| 精品一区二区久久久久久久网站| 在线日本成人| 亚洲专区区免费| 色婷婷综合久久久中文一区二区| 天天操天天操天天操| 热久久这里只有精品| 蜜桃视频欧美| 亚洲精品成人在线播放| 亚洲人成网站影音先锋播放| 精品毛片一区二区三区| 久久久久国产精品www| 欧美黄色一级| 麻豆tv在线播放| 久久综合久久99| 在线观看毛片av| 美女av一区二区| 亚洲小说图片| 黄色在线视频网| 亚洲激情校园春色| 黄色aaa大片| 久久久久久网址| 国产精品一区二区av日韩在线| 91热这里只有精品| 亚洲精品午夜久久久| 色综合久久久久久| 国产精品av电影| 66国产精品| 91精品人妻一区二区三区蜜桃欧美| 91高清视频免费看| jyzzz在线观看视频| 91超碰在线免费观看| 亚洲精品影院在线观看| 后入内射无码人妻一区| 精品美女一区二区| 日韩一级二级| 亚洲小视频在线播放| 久久精品欧美一区二区三区麻豆| 亚洲天堂中文在线| 欧美区在线播放| 欧美伦理在线视频| 在线一区二区不卡| 日本福利一区二区| 直接在线观看的三级网址| 日本一区二区高清视频| 国产乱子伦视频一区二区三区|