前端面試總結

前端開發面試知識點大綱

HTML&CSS

對Web標準的理解、瀏覽器內核差別、兼容性、hack、CSS基本功:佈局、盒子模型、選擇器優先級及使用、HTML五、CSS三、移動端適應javascript

JavaScript

數據類型、面向對象、繼承、閉包、插件、做用域、跨域、原型鏈、模塊化、自定義事件、內存泄漏、事件機制、異步裝載回調、模板引擎、Nodejs、JSON、ajax等。css

其餘

HTTP、安全、正則、優化、重構、響應式、移動端、團隊協做、可維護、SEO、UED、架構、職業生涯html

 

必備知識點

做爲一名前端工程師,不管工做年頭長短都應該必須掌握的知識點:此條由 王子墨 發表在 前端隨筆前端

  1. DOM結構 —— 兩個節點之間可能存在哪些關係以及如何在節點之間任意移動。
  2. DOM操做 ——如何添加、移除、移動、複製、建立和查找節點等。
  3. 事件 —— 如何使用事件,以及IE和標準DOM事件模型之間存在的差異。
  4. XMLHttpRequest —— 這是什麼、怎樣完整地執行一次GET請求、怎樣檢測錯誤。
  5. 嚴格模式與混雜模式 —— 如何觸發這兩種模式,區分它們有何意義。
  6. 盒模型 —— 外邊距、內邊距和邊框之間的關係,及IE8如下版本的瀏覽器中的盒模型
  7. 塊級元素與行內元素 —— 怎麼用CSS控制它們、以及如何合理的使用它們
  8. 浮動元素——怎麼使用它們、它們有什麼問題以及怎麼解決這些問題。
  9. HTML與XHTML——兩者有什麼區別,你以爲應該使用哪個並說出理由。
  10. JSON —— 做用、用途、設計結構。

 

備註:html5

根據本身須要選擇性閱讀,面試題是對理論知識的總結,讓本身學會應該如何表達。資料答案不夠正確和全面,歡迎補充答案、題目;最好是如今網上沒有的。格式不斷修改更新中。java

 

HTML

Doctype做用? 嚴格模式與混雜模式如何區分?它們有何意義?node

  • <!DOCTYPE> 聲明位於文檔中的最前面,處於 <html> 標籤以前。告知瀏覽器的解析器, 用什麼文檔類型 規範來解析這個文檔
  • 嚴格模式的排版和 JS 運做模式是 以該瀏覽器支持的最高標準運行。
  • 在混雜模式中,頁面以寬鬆的向後兼容的方式顯示。模擬老式瀏覽器的行爲以防止站點沒法工做。 (4)、DOCTYPE不存在或格式不正確會致使文檔以混雜模式呈現。

 

行內元素有哪些?塊級元素有哪些? 空(void)元素有那些?jquery

  • CSS規範規定,每一個元素都有display屬性,肯定該元素的類型,每一個元素都有默認的display值, 好比div默認display屬性值爲「block」,成爲「塊級」元素; span默認display屬性值爲「inline」,是「行內」元素。
  • 行內元素有:a b span img input select strong(強調的語氣) 塊級元素有:div ul ol li dl dt dd h1 h2 h3 h4…p
  • 知名的空元素: <br> <hr> <img> <input> <link> <meta>
  • 不爲人知的是: <area> <base> <col> <command> <embed> <keygen> <param> <source> <track> <wbr>

 

link 和@import 的區別是?git

  • link屬於XHTML標籤,而@import是CSS提供的;
  • 頁面被加載的時,link會同時被加載,而@import引用的CSS會等到頁面被加載完再加載;
  • import只在IE5以上才能識別,而link是XHTML標籤,無兼容問題;
  • link方式的樣式的權重 高於@import的權重.

 

瀏覽器的內核分別是什麼?程序員

* IE瀏覽器的內核Trident、Mozilla的Gecko、Chrome的Blink(WebKit的分支)、Opera內核原爲Presto,現爲Blink;

 

常見兼容性問題?

* png24位的圖片在iE6瀏覽器上出現背景,解決方案是作成PNG8.

* 瀏覽器默認的margin和padding不一樣。解決方案是加一個全局的*{margin:0;padding:0;}來統一。

* IE6雙邊距bug:塊屬性標籤float後,又有橫行的margin狀況下,在ie6顯示margin比設置的大。

浮動ie產生的雙倍距離 #box{ float:left; width:10px; margin:0 0 0 100px;}

這種狀況之下IE會產生20px的距離,解決方案是在float的標籤樣式控制中加入 ——_display:inline;將其轉化爲行內屬性。(_這個符號只有ie6會識別)

漸進識別的方式,從整體中逐漸排除局部。

首先,巧妙的使用「\9」這一標記,將IE遊覽器從全部狀況中分離出來。

接着,再次使用「+」將IE8和IE七、IE6分離開來,這樣IE8已經獨立識別。

css

* IE下,可使用獲取常規屬性的方法來獲取自定義屬性,

也可使用getAttribute()獲取自定義屬性;

Firefox下,只能使用getAttribute()獲取自定義屬性.

解決方法:統一經過getAttribute()獲取自定義屬性.

 

* IE下,even對象有x,y屬性,可是沒有pageX,pageY屬性;

Firefox下,event對象有pageX,pageY屬性,可是沒有x,y屬性.

 

* 解決方法:(條件註釋)缺點是在IE瀏覽器下可能會增長額外的HTTP請求數。

* Chrome 中文界面下默認會將小於 12px 的文本強制按照 12px 顯示,

可經過加入 CSS 屬性 -webkit-text-size-adjust: none; 解決.

超連接訪問事後hover樣式就不出現了 被點擊訪問過的超連接樣式不在具備hover和active瞭解決方法是改變CSS屬性的排列順序:

L-V-H-A : a:link {} a:visited {} a:hover {} a:active {}

 

html5有哪些新特性、移除了那些元素?如何處理HTML5新標籤的瀏覽器兼容問題?如何區分 HTML 和 HTML5?

* HTML5 如今已經不是 SGML 的子集,主要是關於圖像,位置,存儲,多任務等功能的增長。

* 繪畫 canvas

用於媒介回放的 video 和 audio 元素

本地離線存儲 localStorage 長期存儲數據,瀏覽器關閉後數據不丟失;

sessionStorage 的數據在瀏覽器關閉後自動刪除

語意化更好的內容元素,好比 article、footer、header、nav、section

表單控件,calendar、date、time、email、url、search

新的技術webworker, websockt, Geolocation

* 移除的元素

純表現的元素:basefont,big,center,font, s,strike,tt,u;

對可用性產生負面影響的元素:frame,frameset,noframes;

支持HTML5新標籤:

* IE8/IE7/IE6支持經過document.createElement方法產生的標籤,

能夠利用這一特性讓這些瀏覽器支持HTML5新標籤,

瀏覽器支持新標籤後,還須要添加標籤默認的樣式:

* 固然最好的方式是直接使用成熟的框架、使用最多的是html5shim框架

如何區分: DOCTYPE聲明\新增的結構元素\功能元素

 

語義化的理解?

  • 用正確的標籤作正確的事情!
  • html語義化就是讓頁面的內容結構化,便於對瀏覽器、搜索引擎解析;
  • 在沒有樣式CCS狀況下也以一種文檔格式顯示,而且是容易閱讀的。
  • 搜索引擎的爬蟲依賴於標記來肯定上下文和各個關鍵字的權重,利於 SEO。
  • 使閱讀源代碼的人對網站更容易將網站分塊,便於閱讀維護理解。

 

 

HTML5的離線儲存?

  • localStorage 長期存儲數據,瀏覽器關閉後數據不丟失;
  • sessionStorage 數據在瀏覽器關閉後自動刪除。

 

(寫)描述一段語義的html代碼

(HTML5中新增長的不少標籤(如:<article>、<nav>、<header>和<footer>等)
就是基於語義化設計原則)

 

iframe有那些缺點?

  • *iframe會阻塞主頁面的Onload事件;
  • *iframe和主頁面共享鏈接池,而瀏覽器對相同域的鏈接有限制,因此會影響頁面的並行加載。 使用iframe以前須要考慮這兩個缺點。若是須要使用iframe,最好是經過javascript 動態給iframe添加src屬性值,這樣能夠能夠繞開以上兩個問題。

 

 

請描述一下 cookies,sessionStorage 和 localStorage 的區別?

  • cookie在瀏覽器和服務器間來回傳遞。
  • sessionStorage和localStorage不會 sessionStorage和localStorage的存儲空間更大;
  • sessionStorage和localStorage有更多豐富易用的接口;
  • sessionStorage和localStorage各自獨立的存儲空間;

 

如何實現瀏覽器內多個標籤頁之間的通訊? (阿里)

調用localstorge、cookies等本地存儲方式

 

 

webSocket如何兼容低瀏覽器?(阿里)

Adobe Flash Socket 、 ActiveX HTMLFile (IE) 、 基於 multipart 編碼發送 XHR 、 基於長輪詢的 XHR

 

CSS

介紹一下CSS的盒子模型?

(1)有兩種, IE 盒子模型、標準 W3C 盒子模型;IE的content部分包含了 border 和 pading;

(2)盒模型: 內容(content)、填充(padding)、邊界(margin)、 邊框(border).

 

 

CSS 選擇符有哪些?哪些屬性能夠繼承?優先級算法如何計算? CSS3新增僞類有那些?

  • 1.id選擇器( # myid)
  • 2.類選擇器(.myclassname)
  • 3.標籤選擇器(div, h1, p)
  • 4.相鄰選擇器(h1 + p)
  • 5.子選擇器(ul < li)
  • 6.後代選擇器(li a)
  • 7.通配符選擇器( * )
  • 8.屬性選擇器(a[rel = 「external」])
  • 9.僞類選擇器(a: hover, li: nth – child)

* 可繼承的樣式: font-size font-family color, UL LI DL DD DT;

* 不可繼承的樣式:border padding margin width height ;

* 優先級就近原則,同權重狀況下樣式定義最近者爲準;

* 載入樣式以最後載入的定位爲準;

 

優先級爲:

!important > id > class > tag

important 比 內聯優先級高

 

 

CSS3新增僞類舉例

  • p:first-of-type 選擇屬於其父元素的首個 <p> 元素的每一個 <p> 元素。
  • p:last-of-type 選擇屬於其父元素的最後 <p> 元素的每一個 <p> 元素。
  • p:only-of-type 選擇屬於其父元素惟一的 <p> 元素的每一個 <p> 元素。
  • p:only-child 選擇屬於其父元素的惟一子元素的每一個 <p> 元素。
  • p:nth-child(2) 選擇屬於其父元素的第二個子元素的每一個 <p> 元素。
  • :enabled :disabled 控制表單控件的禁用狀態。
  • :checked 單選框或複選框被選中。

 

如何居中div?

 

如何居中一個浮動元素?

 

列出display的值,說明他們的做用。

  • block 象塊類型元素同樣顯示。
  • none 缺省值。象行內元素類型同樣顯示。
  • inline-block 象行內元素同樣顯示,但其內容象塊類型元素同樣顯示。
  • list-item 象塊類型元素同樣顯示,並添加樣式列表標記。

 

position的值, relative和absolute定位原點是?

  • *absolute:生成絕對定位的元素,相對於 static 定位之外的第一個父元素進行定位。
  • *fixed:生成絕對定位的元素,相對於瀏覽器窗口進行定位。
  • *relative:生成相對定位的元素,相對於其正常位置進行定位。
  • * static 默認值。沒有定位,元素出如今正常的流中

*(忽略 top, bottom, left, right z-index 聲明)。

* inherit 規定從父元素繼承 position 屬性的值。

 

CSS3有哪些新特性?

CSS3實現圓角(border-radius:8px),陰影(box-shadow:10px),

對文字加特效(text-shadow、),線性漸變(gradient),旋轉(transform)

transform:rotate(9deg) scale(0.85,0.90) translate(0px,-30px) skew(-9deg,0deg);//旋轉,縮放,定位,傾斜

增長了更多的CSS選擇器 多背景 rgba

 

 

一個滿屏 品 字佈局 如何設計?

 

常常遇到的CSS的兼容性有哪些?緣由,解決方法是什麼?

 

爲何要初始化CSS樣式?

– 由於瀏覽器的兼容問題,不一樣瀏覽器對有些標籤的默認值是不一樣的,若是沒對CSS初始化每每會出現瀏覽器之間的頁面顯示差別。

– 固然,初始化樣式會對SEO有必定的影響,但魚和熊掌不可兼得,但力求影響最小的狀況下初始化。

*最簡單的初始化方法就是: * {padding: 0; margin: 0;} (不建議)

淘寶的樣式初始化:

 

absolute的containing block計算方式跟正常流有什麼不一樣?

 

position跟display、margin collapse、overflow、float這些特性相互疊加後會怎麼樣?

 

對BFC規範的理解?

(W3C CSS 2.1 規範中的一個概念,它決定了元素如何對其內容進行定位,以及與其餘元素的關 系和相互做用。)

 

 

css定義的權重

如下是權重的規則:標籤的權重爲1,class的權重爲10,id的權重爲100,如下例子是演示各類定義的權重值:

若是權重相同,則最後定義的樣式會起做用,可是應該避免這種狀況出現

 

解釋下浮動和它的工做原理?清除浮動的技巧

 

用過媒體查詢,針對移動端的佈局嗎?

 

使用 CSS 預處理器嗎?喜歡那個?

SASS

 

若是須要手動寫動畫,你認爲最小時間間隔是多久,爲何?(阿里)

多數顯示器默認頻率是60Hz,即1秒刷新60次,因此理論上最小間隔爲1/60*1000ms = 16.7ms

 

display:inline-block 何時會顯示間隙?(攜程)

移除空格、使用margin負值、使用font-size:0、letter-spacing、word-spacing

 

JavaScript

JavaScript原型,原型鏈 ? 有什麼特色?

 

eval是作什麼的?

它的功能是把對應的字符串解析成JS代碼並運行; 應該避免使用eval,不安全,很是耗性能(2次,一次解析成js語句,一次執行)。

 

null,undefined 的區別?

 

寫一個通用的事件偵聽器函數

 Node.js的適用場景?

高併發、聊天、實時消息推送

 

介紹js的基本數據類型

 

Javascript如何實現繼承?

經過原型和構造器

 

[「1″, 「2」, 「3」].map(parseInt) 答案是多少?

[1, NaN, NaN] 由於 parseInt 須要兩個參數 (val, radix),其中 radix 表示解析時用的基數。map 傳了 3 個 (element, index, array),對應的 radix 不合法致使解析失敗。

 

如何建立一個對象? (畫出此對象的內存圖)

 

談談This對象的理解

this是js的一個關鍵字,隨着函數使用場合不一樣,this的值會發生變化。

可是有一個總原則,那就是this指的是調用函數的那個對象。

this通常狀況下:是全局對象Global。 做爲方法調用,那麼this就是指這個對象

 

事件是?IE與火狐的事件機制有什麼區別? 如何阻止冒泡?

1. 咱們在網頁中的某個操做(有的操做對應多個事件)。例如:當咱們點擊一個按鈕就會產生一個事件。是能夠被 JavaScript 偵測到的行爲。

2. 事件處理機制:IE是事件冒泡、火狐是 事件捕獲;

3. ev.stopPropagation();

 

什麼是閉包(closure),爲何要用它?

執行say667()後,say667()閉包內部變量會存在,而閉包內部函數的內部變量不會存在.使得Javascript的垃圾回收機制GC不會收回say667()所佔用的資源,由於say667()的內部函數的執行須要依賴say667()中的變量。這是對閉包做用的很是直白的描述.

 

「use strict」;是什麼意思 ? 使用它的好處和壞處分別是什麼?

如何判斷一個對象是否屬於某個類?

new操做符具體幹了什麼呢?

一、建立一個空對象,而且 this 變量引用該對象,同時還繼承了該函數的原型。
二、屬性和方法被加入到 this 引用的對象中。
三、新建立的對象由 this 所引用,而且最後隱式的返回 this 。

 

Javascript中,有一個函數,執行時對象查找時,永遠不會去查找原型,這個函數是?

 

JSON 的瞭解?

JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。

它是基於JavaScript的一個子集。數據格式簡單, 易於讀寫, 佔用帶寬小 {'age':'12', 'name':'back'}

 

js延遲加載的方式有哪些?

defer和async、動態建立DOM方式(用得最多)、按需異步載入js

 

ajax 是什麼?

 

同步和異步的區別?

 

如何解決跨域問題?

 

模塊化怎麼作?當即執行函數,不暴露私有成員

 

AMD(Modules/Asynchronous-Definition)、CMD(Common Module Definition)規範區別?

 

異步加載的方式有哪些?

(1) defer,只支持IE

(2) async:

(3) 建立script,插入到DOM中,加載完畢後callBack

 

documen.write和 innerHTML的區別

  • document.write只能重繪整個頁面
  • innerHTML能夠重繪頁面的一部分

 

.call() 和 .apply() 的區別?

例子中用 add 來替換 sub,add.call(sub,3,1) == add(3,1) ,因此運行結果爲:alert(4);

注意:js 中的函數實際上是對象,函數名是對 Function 對象的引用。

 

Jquery與jQuery UI 有啥區別?

  • *jQuery是一個js庫,主要提供的功能是選擇器,屬性修改和事件綁定等等。
  • *jQuery UI則是在jQuery的基礎上,利用jQuery的擴展性,設計的插件。
  • 提供了一些經常使用的界面元素,諸如對話框、拖動行爲、改變大小行爲等等

 

JQuery的源碼看過嗎?能不能簡單說一下它的實現原理?

 

jquery 中如何將數組轉化爲json字符串,而後再轉化回來?

jQuery中沒有提供這個功能,因此你須要先編寫兩個jQuery的擴展:

 

針對 jQuery 的優化方法?

*基於Class的選擇性的性能相對於Id選擇器開銷很大,由於需遍歷全部DOM元素。

*頻繁操做的DOM,先緩存起來再操做。用Jquery的鏈式調用更好。

好比:var str=$("a").attr("href"); *for (var i = size; i < arr.length; i++) {}

for 循環每一次循環都查找了數組 (arr) 的.length 屬性,在開始循環的時候設置一個變量來存儲這個數字,可讓循環跑得更快:

for (var i = size, length = arr.length; i < length; i++) {}

 

JavaScript中的做用域與變量聲明提高?

 

如何編寫高性能的Javascript?

 

那些操做會形成內存泄漏?

內存泄漏指任何對象在您再也不擁有或須要它以後仍然存在。

垃圾回收器按期掃描對象,並計算引用了每一個對象的其餘對象的數量。若是一個對象的引用數量爲 0(沒有其餘對象引用過該對象),或對該對象的唯一引用是循環的,那麼該對象的內存便可回收。

setTimeout 的第一個參數使用字符串而非函數的話,會引起內存泄漏。

閉包、控制檯日誌、循環(在兩個對象彼此引用且彼此保留時,就會產生一個循環)

 

JQuery一個對象能夠同時綁定多個事件,這是如何實現的?

 

如何判斷當前腳本運行在瀏覽器仍是node環境中?(阿里)

經過判斷Global對象是否爲window,若是不爲window,當前腳本沒有運行在瀏覽器中

 

其餘問題

你遇到過比較難的技術問題是?你是如何解決的?

常使用的庫有哪些?經常使用的前端開發工具?開發過什麼應用或組件?

頁面重構怎麼操做?

列舉IE 與其餘瀏覽器不同的特性?

99%的網站都須要被重構是那本書上寫的?

什麼叫優雅降級和漸進加強?

WEB應用從服務器主動推送Data到客戶端有那些方式?

 

對Node的優勢和缺點提出了本身的見解?

*(優勢)由於Node是基於事件驅動和無阻塞的,因此很是適合處理併發請求, 所以構建在Node上的代理服務器相比其餘技術實現(如Ruby)的服務器表現要好得多。 此外,與Node代理服務器交互的客戶端代碼是由javascript語言編寫的, 所以客戶端和服務器端都用同一種語言編寫,這是很是美妙的事情。

*(缺點)Node是一個相對新的開源項目,因此不太穩定,它老是一直在變, 並且缺乏足夠多的第三方庫支持。看起來,就像是Ruby/Rails當年的樣子。

 

你有哪些性能優化的方法?(看雅虎14條性能優化原則)

(1) 減小http請求次數:CSS Sprites, JS、CSS源碼壓縮、圖片大小控制合適;網頁Gzip,CDN託管,data緩存 ,圖片服務器。

(2) 前端模板 JS+數據,減小因爲HTML標籤致使的帶寬浪費,前端用變量保存AJAX請求結果,每次操做本地變量,不用請求,減小請求次數

(3) 用innerHTML代替DOM操做,減小DOM操做次數,優化javascript性能。

(4) 當須要設置的樣式不少時設置className而不是直接操做style。

(5) 少用全局變量、緩存DOM節點查找的結果。減小IO讀取操做。

(6) 避免使用CSS Expression(css表達式)又稱Dynamic properties(動態屬性)。

(7) 圖片預加載,將樣式表放在頂部,將腳本放在底部 加上時間戳。

(8) 避免在頁面的主體佈局中使用table,table要等其中的內容徹底下載以後纔會顯示出來,顯示比div+css佈局慢。

 

http狀態碼有那些?分別表明是什麼意思?

 

一個頁面從輸入 URL 到頁面加載顯示完成,這個過程當中都發生了什麼?(流程說的越詳細越好)

  • 查找瀏覽器緩存
  • DNS解析、查找該域名對應的IP地址、重定向(301)、發出第二個GET請求
  • 進行HTTP協議會話
  • 客戶端發送報頭(請求報頭)
  • 服務器回饋報頭(響應報頭)
  • html文檔開始下載
  • 文檔樹創建,根據標記請求所需指定MIME類型的文件
  • 文件顯示

{瀏覽器這邊作的工做大體分爲如下幾步:

加載:根據請求的URL進行域名解析,向服務器發起請求,接收文件(HTML、JS、CSS、圖象等)。

解析:對加載到的資源(HTML、JS、CSS等)進行語法解析,建議相應的內部數據結構(好比HTML的DOM樹,JS的(對象)屬性表,CSS的樣式規則等等)}

 

除了前端之外還了解什麼其它技術麼?你最最厲害的技能是什麼?

你經常使用的開發工具是什麼,爲何?

對前端界面工程師這個職位是怎麼樣理解的?它的前景會怎麼樣?

  • 前端是最貼近用戶的程序員,比後端、數據庫、產品經理、運營、安全都近。
    • 實現界面交互
    • 提高用戶體驗
    • 有了Node.js,前端能夠實現服務端的一些事情
  • 前端是最貼近用戶的程序員,前端的能力就是能讓產品從 90分進化到 100 分,甚至更好,
  • 參與項目,快速高質量完成實現效果圖,精確到1px;
  • 與團隊成員,UI設計,產品經理的溝通;
  • 作好的頁面結構,頁面重構和用戶體驗;
  • 處理hack,兼容、寫出優美的代碼格式;
  • 針對服務器的優化、擁抱最新前端技術。

 

加班的見解?

加班就像借錢,原則應當是------救急不救窮

 

平時如何管理你的項目?

  • 先期團隊必須肯定好全局樣式(globe.css),編碼模式(utf-8) 等;
  • 編寫習慣必須一致(例如都是採用繼承式的寫法,單樣式都寫成一行);
  • 標註樣式編寫人,各模塊都及時標註(標註關鍵樣式調用的地方);
  • 頁面進行標註(例如 頁面 模塊 開始和結束);
  • CSS跟HTML 分文件夾並行存放,命名都得統一(例如style.css);
  • JS 分文件夾存放 命名以該JS功能爲準的英文翻譯。
  • 圖片採用整合的 images.png png8 格式文件使用 儘可能整合在一塊兒使用方便未來的管理

 

如何設計突發大規模併發架構?

說說最近最流行的一些東西吧?常去哪些網站?

 

移動端(Android IOS)怎麼作好用戶體驗?

  • 清晰的視覺縱線、信息的分組、極致的減法、
  • 利用選擇代替輸入、標籤及文字的排布方式、
  • 依靠明文確認密碼、合理的鍵盤利用、

 

你在如今的團隊處於什麼樣的角色,起到了什麼明顯的做用?

你認爲怎樣纔是全端工程師(Full Stack developer)?

介紹一個你最得意的做品吧?

你的優勢是什麼?缺點是什麼?

如何管理前端團隊?

最近在學什麼?能談談你將來3,5年給本身的規劃嗎?

相關文章
相關標籤/搜索