摘要:工作中總結(jié)的一些比較重要的前端技能,覺得在面試中比較合適提問,即能查看出面試者的技術(shù)功底,又能考察其知識體系的廣度。異步編程的考察,其關(guān)鍵字的使用,與的關(guān)系,同時可以深入考察總共有幾種異步編程的方式。
工作中總結(jié)的一些比較重要的前端技能,覺得在面試中比較合適提問,即能查看出面試者的技術(shù)功底,又能考察其知識體系的廣度。適用于應(yīng)屆生和工作年限兩年下的同學(xué),掌握下面的知識基本滿足工作需求了。更高年限的開發(fā)工程師則應(yīng)該更注重架構(gòu)能力而不是具體的技術(shù)細(xì)節(jié)。
HTML5語義化標(biāo)簽,meta元數(shù)據(jù)標(biāo)簽,考察其對語義化的理解。
draggale屬性的api,dragstart, drop, dataTransfer等內(nèi)容,考察其對新技術(shù)的使用。
CSS3
盒子模型是什么,怎么計算的?
盒子模型指的是瀏覽器將文檔流從視覺上渲染為不同矩形框的組合,每個元素都被渲染為一個矩形框,包含內(nèi)容區(qū)域(文本、圖片等真實(shí)內(nèi)容的區(qū)域)和可選的margin/border/padding三個區(qū)域,中文名為外邊距、邊框和填充。包含關(guān)系為margin > border > padding > content。
計算方式為自上而下,4個盒子區(qū)域的寬度和高度都支持固定值進(jìn)行設(shè)置,同時margin/padding支持百分比,計算的高度和寬度值都依據(jù)父元素的content區(qū)域?qū)挾龋琧ontent區(qū)域也支持百分比,不過高度和寬度分別對應(yīng)父元素content區(qū)域的高度和寬度,border不支持百分比。content區(qū)域的默認(rèn)寬高由盒子類型和是否包含有其他盒子來進(jìn)行計算,其余區(qū)域均為0。
盒子模型包含幾種類型,怎么轉(zhuǎn)換。
盒子模型相關(guān)的一些DOM屬性offsetHeight/offsetTop/scrollHeight/clientHeight分別指什么?
offsetHeight: 包含border、padding和content區(qū)域的高度總和。 offsetTop: 元素border上邊界到父元素content上邊界的距離。 scrollHeight: 沒有滾動條的情況下,元素的offsetHeight總高度。 clientHeight: 瀏覽器視口的高度。
選擇器實(shí)現(xiàn)原理以及其權(quán)重和最右匹配的概念。
圣杯布局(大屏幕分為頂部、底部和中間三個縱向容器,小屏幕時橫列為5項(xiàng))的幾種實(shí)現(xiàn)方式(同時考察@media媒體查詢)。
bootstrap框架的響應(yīng)式布局實(shí)現(xiàn)原理,考察viewport視口,媒體查詢的邊界條件。
垂直居中對齊的方式,考察元素的文字基線。
bootstrap輸入框組怎么實(shí)現(xiàn),考察:first-child等偽元素和垂直居中對齊。
JavascriptJs包含的基礎(chǔ)類型,null/undefined/boolean/number/string/object/Symbol。array, function, object實(shí)例和原型鏈對應(yīng)關(guān)系。
數(shù)組的常用函數(shù),如unshift/slice/map/forEach/filter/some/every/reduce,同時考察哪些返回新的,哪些修改了原數(shù)組。
嘗試給數(shù)組添加一個通用方法makeIndexObj,使得可以根據(jù)某個參數(shù)作為key值重構(gòu)為新對象。
Object.defineProperty(Array.prototype, "makeIndexObj", { value: function (key) { let result = {}; this.forEach(item => { // 這里借用了jQuery的深度復(fù)制,可以考察其具體的實(shí)現(xiàn) result[item[key]] = $.extend(true, {}, item); }); return result; } });
考察對象的屬性以及其特征,包括defineProperty和屬性訪問器定義屬性的區(qū)別,以及屬性的enumerable, configurable, writable, value, get, set特征,同時考察深度復(fù)制和功能體邊界檢測(支持多key值,輸入的是一個數(shù)組或字符串)。
淺拷貝和深度拷貝的實(shí)現(xiàn),考察Object.assign(), for in遍歷, $.extend()等。
let, var, const的區(qū)別和優(yōu)劣,考察變量提升,常量實(shí)現(xiàn)方式,同時深入考察如何實(shí)現(xiàn)真正的不可修改的對象。
cookie,localstorage, sessionstorage的區(qū)別,考察空間限制,哪些和服務(wù)器交互,常見應(yīng)用場景。
es6箭頭函數(shù) => 的簡化寫法和作用,考察對參數(shù)的要求和自動返回值以及this強(qiáng)制綁定運(yùn)行環(huán)境。
事件捕獲和冒泡的方式,考察addEventListener和attachEvent事件,以及jQuery on/bind/off/die/live等常用方法的區(qū)別和關(guān)系。
兄弟元素內(nèi)容互相覆蓋,事件如何觸發(fā)??疾炫c冒泡的混淆,以及元素碰撞檢測。
AJAX的原理以及跨域原理和方法,可以考察瀏覽器和服務(wù)端HTTP通信。
Promise異步編程,考察其基本用法,常用race/all方法,異常捕獲方式。
異步編程Generator的考察,其關(guān)鍵字yield的使用,與Promise的關(guān)系,同時可以深入考察js總共有幾種異步編程的方式。
this對象的綁定方式,總共包含有默認(rèn)綁定、隱含綁定、明確綁定、new綁定,每種的應(yīng)用場景闡述和內(nèi)部原理。
閉包,閉包如何產(chǎn)生以及其作用和副作用。
Vue MVVM框架MVVM框架解決了什么問題,帶來了什么問題。考察Vue的特性,如雙向數(shù)據(jù)綁定、模塊化、組件化、模板語言等優(yōu)勢,隱藏實(shí)現(xiàn)細(xì)節(jié)、不利于問題追查、過度封裝影響性能的弊端。是否使用過官方vue devtools開發(fā)工具調(diào)試。
雙向數(shù)據(jù)綁定如何實(shí)現(xiàn),考察es5 getter/setter方法,以及其對數(shù)組對象等完全重寫,深入考察設(shè)計模式
的觀察者模式和訂閱者模式的方式以及區(qū)別。
如何追蹤數(shù)據(jù)變化,數(shù)組的哪些改變方式不能被檢測到,如直接改變length,元素索引修改,同時還有對象的屬性修改。為什么這些不能被檢測到,因?yàn)楝F(xiàn)有js語言層面不支持,只能對既有方法進(jìn)行重寫。
nextTick的使用場景,為什么會使用nextTick,事件驅(qū)動,同一個執(zhí)行周期內(nèi)去重回調(diào)事件提高效率減少資源消耗。
組件的優(yōu)勢,模塊封裝有什么優(yōu)劣,組件如何進(jìn)行模塊化:props down, events up。
單頁面復(fù)雜應(yīng)用應(yīng)該new多少個vue對象,不同vue對象數(shù)據(jù)如何傳遞,公有函數(shù)如何聲明。考察模塊的封裝和耦合以及其取舍,引入vuex.js。
vuex和vue-router是否使用過,都解決了什么問題。不深究第三方庫,只考察廣度和技術(shù)棧以及其理解程度。
綜合知識url從輸入到返回都經(jīng)歷了什么過程?考察范圍非??植溃?/p>
1. 瀏覽器讀取最近瀏覽,自動推薦網(wǎng)址. 2. 拿到url,嘗試讀取緩存。 3. 緩存不存在,構(gòu)建響應(yīng)頭,發(fā)起請求。其中包括dns解析,tcp建連,發(fā)起http請求。 4. 服務(wù)器接收到客戶端請求,解析并處理返回數(shù)據(jù)。 5. 瀏覽器接收到響應(yīng)頭,讀取狀態(tài)碼等信息,進(jìn)行緩存或讀取緩存或再次發(fā)起請求。 6. 讀取響應(yīng)體,檢測數(shù)據(jù)類型,進(jìn)行解析。 7. 渲染頁面。
在這些過程中,每一個都可以深入詢問,如:
1. 網(wǎng)絡(luò)通信方向dns解析的過程,一共分為幾次,根域名服務(wù)器、權(quán)威服務(wù)器、代理服務(wù)器等概念。 2. tcp建連的過程,三次握手,`syn, ack+syn, ack`,以及斷開連接的`wait time state`的作用。 3. 如何進(jìn)行緩存和格式的控制,請求頭和響應(yīng)頭的主體參數(shù)的作用。 4. 常見的狀態(tài)碼的含義,如200、304、404、500等,不同分段指向什么錯誤。 5. 瀏覽器的請求控制,對同一個域名下最多保持6個請求,如何復(fù)用連接,keep-alive的作用。 6. 渲染頁面的過程,DOM、BOM、ECMAScript的關(guān)系,什么為阻塞,什么非阻塞。document.ready是準(zhǔn)備好了什么。
頁面性能優(yōu)化
圖片合并、異步加載、js壓縮、CDN加速等
兼容性
常見的滾輪事件、事件對象等,主要看個人遇到的問題,不要挑偏僻的問。對兼容性的歷史遺留過程的了解。出現(xiàn)問題常用的解決方案,查文檔常用的網(wǎng)站,如MDN、w3c、segmentfault、stackoverflow、github等官方文檔和程序員交友社區(qū),考察其善用搜索引擎的能力。
git倉庫管理
如何構(gòu)建新的分支和合并分支,出現(xiàn)沖突如何處理,如何回滾版本。主要考察合作開發(fā)代碼的經(jīng)驗(yàn)以及對倉庫的理解。
算法相關(guān)
都了解什么排序算法,插入排序和快速排序和冒泡排序的事件復(fù)雜度,快速排序的思想,手寫快排,快排的最優(yōu)情況和最差情況。js使用了什么排序算法,深入考察for i++和[].forEach的效率,為什么。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/112597.html
摘要:獲取的對象范圍方法獲取的是最終應(yīng)用在元素上的所有屬性對象即使沒有代碼,也會把默認(rèn)的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個光禿禿的元素,方法返回對象中屬性值如果有就是據(jù)我測試不同環(huán)境結(jié)果可能有差異而就是。 花了很長時間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點(diǎn)個贊,點(diǎn)個star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項(xiàng)目地址 https:...
摘要:手冊網(wǎng)超級有用的前端基礎(chǔ)技術(shù)面試問題收集前端面試題目及答案匯總史上最全前端面試題含答案常見前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過程中最容易出現(xiàn)的問題前端面試題整理騰訊前端面試經(jīng)驗(yàn)前端基礎(chǔ)面試題部分最新前端面試題攻略前端面試前端入 手冊網(wǎng):http://www.shouce.ren/post/index 超級有用的前端基礎(chǔ)技術(shù)面試問題收集:http://www.codec...
摘要:手冊網(wǎng)超級有用的前端基礎(chǔ)技術(shù)面試問題收集前端面試題目及答案匯總史上最全前端面試題含答案常見前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過程中最容易出現(xiàn)的問題前端面試題整理騰訊前端面試經(jīng)驗(yàn)前端基礎(chǔ)面試題部分最新前端面試題攻略前端面試前端入 手冊網(wǎng):http://www.shouce.ren/post/index 超級有用的前端基礎(chǔ)技術(shù)面試問題收集:http://www.codec...
摘要:一基礎(chǔ)接口的意義百度規(guī)范擴(kuò)展回調(diào)抽象類的意義我的前端面試經(jīng)歷百度前端掘金博主就讀于電子科技大學(xué),大三狗一枚面試是個漫長的過程,從海投到收獲電話面試,一面二面三面,一個步驟出錯那么后面就宣告終結(jié)。 一道常被人輕視的前端 JS 面試題 - 前端 - 掘金 目錄前言第一問第二問變量聲明提升函數(shù)表達(dá)式第三問第四問第五問第六問構(gòu)造函數(shù)的返回值第七問最后前言 年前剛剛離職了,分享下我曾經(jīng)出過的一道...
摘要:一基礎(chǔ)接口的意義百度規(guī)范擴(kuò)展回調(diào)抽象類的意義想不想通過一線互聯(lián)網(wǎng)公司面試文檔整理為電子書掘金簡介谷歌求職記我花了八個月準(zhǔn)備谷歌面試掘金原文鏈接翻譯者 【面試寶典】從對象深入分析 Java 中實(shí)例變量和類變量的區(qū)別 - 掘金原創(chuàng)文章,轉(zhuǎn)載請務(wù)必保留原出處為:http://www.54tianzhisheng.cn/... , 歡迎訪問我的站點(diǎn),閱讀更多有深度的文章。 實(shí)例變量 和 類變量...
閱讀 3590·2021-11-04 16:06
閱讀 3589·2021-09-09 11:56
閱讀 853·2021-09-01 11:39
閱讀 905·2019-08-29 15:28
閱讀 2299·2019-08-29 15:18
閱讀 836·2019-08-29 13:26
閱讀 3337·2019-08-29 13:22
閱讀 1051·2019-08-29 12:18