精品国产一级毛片大全,毛片一级在线,毛片免费观看的视频在线,午夜毛片福利

我要投稿 投訴建議

web前端面試題

時間:2023-02-22 12:31:39 面試試題 我要投稿

web前端面試題

  以下各問題來自于本人在各公司應(yīng)聘時被提問的問題,特地整理出來,有錯誤或不同意見的歡迎評論指出。因各大公司面試還未結(jié)束,本文不透露題目具體出處,且會打亂順序。

web前端面試題

  另注:問方和答方均默認(rèn)所問瀏覽器為主流瀏覽器(IE,chrome,firefox,Safari,Opera)

  技術(shù)問答題:

  HTTP常見的狀態(tài)碼有哪些?分別表示什么意思?

  200:OK,一切正常

  302:重定向

  304:未修改

  403:服務(wù)器禁止訪問

  404:找不到請求的資源

  500:服務(wù)端錯誤

  HTTP狀態(tài)碼中,4**和5**有什么區(qū)別?

  4**是請求錯誤,例如未經(jīng)授權(quán)的請求(403),錯誤的請求地址(404),錯誤的請求方法(405)

  5**是服務(wù)端錯誤,例如腳本運(yùn)行出錯(500)

  JS DOM中,如何綁定和移除事件?

  所有添加:domNode.onevent = function,例如document.onclick = function() { }

  所有移除:domNode.onevent = null; 例如document.onclick = null;

  非IE添加:domNode.addEventListener("event", function() { }),例如document.addEventListener("click", function() { })

  非IE移除:domNode.removeEventListener("event", function() { }),例如document.removeEventListener("click", function() { })

  IE添加:domNode.attachEvent("on" + "event", function() {}),例如document.attachEvent("onclick", function() { })

  IE移除:domNode.detachEvent("on" + "event", function() {}),例如document.detachEvent("onclick",function() {})

  瀏覽器的緩存機(jī)制是怎樣的?通過報(bào)頭的哪個字段來實(shí)現(xiàn)?

  Expires:服務(wù)器允許瀏覽器在這個時間前使用該資源緩存

  Cache-control:作用和Expires類似,但優(yōu)先級更高,且可選值更多。值可以是public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age。其中,max-age值最常用。

  Last-Modified / If-Modified-Since:配合Cache-Control使用。

  Etag / If-None-Match:也要配合Cache-Control使用。注意,Etag優(yōu)先級比Last-Modified高,服務(wù)器會優(yōu)先比對Etag。

  Public指示響應(yīng)可被任何緩存區(qū)緩存。

  Private指示對于單個用戶的整個或部分響應(yīng)消息,不能被共享緩存處理。這允許服務(wù)器僅僅描述當(dāng)用戶的部分響應(yīng)消息,此響應(yīng)消息對于其他用戶的請求無效。

  no-cache指示請求或響應(yīng)消息不能緩存

  no-store用于防止重要的信息被無意的發(fā)布。在請求消息中發(fā)送將使得請求和響應(yīng)消息都不使用緩存。

  max-age指示客戶機(jī)可以接收生存期不大于指定時間(以秒為單位)的響應(yīng)。

  min-fresh指示客戶機(jī)可以接收響應(yīng)時間小于當(dāng)前時間加上指定時間的響應(yīng)。

  max-stale指示客戶機(jī)可以接收超出超時期間的響應(yīng)消息。如果指定max-stale消息的值,那么客戶機(jī)可以接收超出超時期指定值之內(nèi)的響應(yīng)消息。

  Last-Modified:標(biāo)示這個響應(yīng)資源的最后修改時間。web服務(wù)器在響應(yīng)請求時,告訴瀏覽器資源的最后修改時間。

  If-Modified-Since:當(dāng)資源過期時(使用Cache-Control標(biāo)識的max-age),發(fā)現(xiàn)資源具有Last-Modified聲明,則再次向web服務(wù)器請求時帶上頭 If-Modified-Since,表示請求時間。web服務(wù)器收到請求后發(fā)現(xiàn)有頭If-Modified-Since則與被請求資源的最后修改時間進(jìn)行比對。若最后修改時間較新,說明資源又被改動過,則響應(yīng)整片資源內(nèi)容(寫在響應(yīng)消息包體內(nèi)),HTTP 200;若最后修改時間較舊,說明資源無新修改,則響應(yīng)HTTP 304 (無需包體,節(jié)省瀏覽),告知瀏覽器繼續(xù)使用所保存的cache。

  Etag:web服務(wù)器響應(yīng)請求時,告訴瀏覽器當(dāng)前資源在服務(wù)器的唯一標(biāo)識(生成規(guī)則由服務(wù)器覺得)。Apache中,ETag的值,默認(rèn)是對文件的索引節(jié)(INode),大小(Size)和最后修改時間(MTime)進(jìn)行Hash后得到的。

  If-None-Match:當(dāng)資源過期時(使用Cache-Control標(biāo)識的max-age),發(fā)現(xiàn)資源具有Etage聲明,則再次向web服務(wù)器請求時帶上頭If-None-Match (Etag的值)。web服務(wù)器收到請求后發(fā)現(xiàn)有頭If-None-Match 則與被請求資源的相應(yīng)校驗(yàn)串進(jìn)行比對,決定返回200或304。

  請求資源前,先查看緩存中是否有未過期且未修改的相同資源,如果有,直接在緩存中獲取而不是向服務(wù)器索求;如果沒有,并且服務(wù)器允許緩存,則將資源緩存在本地。

  相關(guān)字段及作用:

  HTML語義化是什么意思?有什么作用?

  首先是對維護(hù)者友好,維護(hù)你代碼的人,能通過你的HTML代碼輕松理解你的意圖;

  其次是對搜索引擎友好,搜索引擎不會抓取你的CSS屬性,所以,語義化能讓搜索引擎更好的抓到你想表達(dá)的東西,更容易讓搜索引擎理解你的網(wǎng)站架構(gòu);

  另外就是對用戶友好,當(dāng)然大部分用戶都只是用眼睛看你的網(wǎng)站,所以可以通過CSS樣式來達(dá)到這個目的。但是,盲人是沒法看到的,他們只能通過輔助設(shè)備來實(shí)現(xiàn),但同樣的,這些設(shè)備只能識別語義化的HTML。

  簡單的來說,語義化就是讓該做某件事的東西來做那件事。比如,HTML中的各級標(biāo)題如H1等等,我們當(dāng)然可以用div、span加上各種樣式來實(shí)現(xiàn),但是,那相當(dāng)于用拖拉機(jī)載客,能實(shí)現(xiàn),但是腫不實(shí)用。同樣的例子還有header,footer等標(biāo)簽。

  作用:

  ajax怎么實(shí)現(xiàn)?

  通過瀏覽器的XMLHttpRequest(非IE)或ActiveXObject(IE)對象,異步發(fā)送數(shù)據(jù),并執(zhí)行回調(diào)。具體實(shí)現(xiàn)代碼如下:(代碼來源:http://www.jb51.net/article/23858.htm)

  [javascript] view plaincopyprint?

  function ajaxFunction(){

  var http_request;

  if (window.XMLHttpRequest) {

  http_request = new XMLHttpRequest();

  } else if (window.ActiveXObject) {

  // IE

  try {

  http_request = new ActiveXObject("Msxml2.XMLHTTP");

  } catch (e) {

  try {

  http_request = new ActiveXObject("Microsoft.XMLHTTP");

  } catch (e) {

  alert("您的瀏覽器不支持Ajax");

  return false;

  }

  }

  }

  http_request.onreadystatechange = alertContents;

  http_request.open('GET', url, true);

  http_request.send(null);

  }

  function alertContents() {

  if (http_request.readyState == 4) {

  if (http_request.status == 200) {

  alert(http_request.responseText);

  } else {

  alert('There was a problem with the request.');

  }

  }

  }

  字符串拼接改良方案

  把要拼接的字符串寫入數(shù)組arr,然后調(diào)用arr.join("");

  title和alt的區(qū)別?

  都是提示詞。簡單的說,title給人看,alt給引擎看

  CSS選擇器有哪些?

  通配選擇器(*),標(biāo)簽選擇器(tag),類選擇器(.class),id選擇器(#id),屬性選擇器(selector[attr="val"]),后代選擇器(selector1 selector2),子代選擇器(selector1 > selector2),相鄰選擇器(selector1 ~ selector2),偽元素(selector:first-child等),偽類(selector:hover等)。叫法可能不大一樣,所以舉出一些例子供參考。

  function foo(){ console.log(this); }; foo.call(null);

  window。call第一個參數(shù)為null,所以調(diào)用者為全局,也就是window,而this指向調(diào)用者

  DOCTYPE作用及意義

  為了告訴瀏覽器以什么標(biāo)準(zhǔn)來解析文檔。這是因?yàn)椴糠志W(wǎng)頁并沒有遵循標(biāo)準(zhǔn),或者遵循的是舊版本的標(biāo)準(zhǔn)。

  具體用法,可以參考:http://www.jb51.net/web/34217.html

  readyState有哪些值?各代表什么?

  0 - (未初始化)還沒有調(diào)用send()方法

  1 - (載入)已調(diào)用send()方法,正在發(fā)送請求

  2 - (載入完成)send()方法執(zhí)行完成,已經(jīng)接收到全部響應(yīng)內(nèi)容

  3 - (交互)正在解析響應(yīng)內(nèi)容

  4 - (完成)響應(yīng)內(nèi)容解析完成,可以在客戶端調(diào)用了

  js閉包概念

  js函數(shù)里聲明的局部變量會在退出函數(shù)時被銷毀。而閉包則是保留對局部變量的引用,使其久居內(nèi)存。

  HTML5和HTML4相比多出哪些功能?CSS3和CSS2相比多出哪些功能?

  HTML5:表單驗(yàn)證、websocket、語義化標(biāo)簽等等

  CSS3:動畫,計(jì)算,新的屬性

  less是什么?有什么特點(diǎn)?如何判斷l(xiāng)ess的兼容性

  less是一種CSS預(yù)編譯器,在CSS原有基礎(chǔ)上引入了變量、函數(shù)等元素,使得CSS更容易維護(hù)、擴(kuò)充。

  less是靠less.js來解析的,所以,與瀏覽器沒有關(guān)系。IE6+和其他主流瀏覽器都可以使用less

  JS的屬性可以直接在構(gòu)造函數(shù)中定義,也可以在原型中定義。兩者有什么不同?

  前者定義是寫在內(nèi)存中,而后者是寫在硬盤中

  Array(6).join('a')結(jié)果是多少?

  "aaaaa"。join是指數(shù)組每一項(xiàng)用join的參數(shù)隔開。

  123456['toString']['length'];

  1。Number.toString是一個函數(shù),長度為1

  {}+'a'<{}+'b';

  false。{}+"a"會轉(zhuǎn)化成數(shù)字相加,結(jié)果為NaN。NaN與NaN比較永遠(yuǎn)返回false

  var arr = [1,2,3,4,5,6];arr.splice(1,3);arr.toString();

  156。splice(index, length)。第一個參數(shù)表示開始切割的下標(biāo),第二個是切割的長度。注意這個切割是從原數(shù)組中去除

  var arr = [1,2,3,4,5,6];arr.slice(1,3)['toString']();

  23。和上例不同,slice(index1, index2)第一個參數(shù)表示開始切割的下標(biāo),第二個參數(shù)是結(jié)束切割的下標(biāo)(不含)。且這個切割返回切除部分。

  ({a:1,b:2,c:3})[['b']];

  2、寫一個hack樣式實(shí)現(xiàn) IE6、IE7、firefox 下分別使用不同顏色

  以下分別用條件注釋和屬性前綴法實(shí)現(xiàn)

  [css] view plaincopyprint?

  [css] view plaincopyprint?

  color: #67f; // firefox, IE6, IE7

  *color: #667; // IE6,IE7

  _color: #666; // IE6 only

  /* 只在IE6下生效 */

  /* 只在IE7下生效 */

  color: #777;

  /* 在非IE下生效 */

  項(xiàng)目規(guī)劃題:

  假如你是項(xiàng)目負(fù)責(zé)人,你會如何規(guī)劃整個項(xiàng)目的CSS文件?

  reset.css

  public.css

  各模塊按文件夾分配CSS,或直接以模塊劃分CSS

  如何在項(xiàng)目中避免和其他小組沖突?例如類名的命名?

  在類名中加模塊前綴,例如登錄的提交按鈕命名可以為"login-btn-submit"(個人用法,不一樣的歡迎提出來交流)

  邏輯題:

  七點(diǎn)四十五分的時候,時針和分針之間的角度是多少?

  37.5°

  給你N個蘋果和一座天平,其中一個蘋果比較重,其他蘋果一樣重。假設(shè)其他因素完全一樣,假設(shè)天平兩側(cè)可以放無限個蘋果。現(xiàn)在要找出那個較重的蘋果,需要使用幾次天平。求最差情況的最優(yōu)解。(設(shè)計(jì)一種算法,讓平均次數(shù)最少)

  想說二分的都準(zhǔn)備掛吧2333,不信想一下N=8的情況。

  我能想到的最好方案是三分,即N/3并向上取整*2,剩下的作為第三堆。即每次天平稱的時候兩邊是ceil(N/3)。例如上面說的,N=8的時候,按二分的思路,第一次稱是4,4,第二次稱的時候是2,2,第三次是1,1,總共三次。而用三分的思路,第一次是3,3,2,第二次(最壞)是1,1,1,只需要兩次。

  代碼實(shí)戰(zhàn)題:

  拖拽效果實(shí)現(xiàn)(兼容IE跟chrome):

  總體思路:點(diǎn)擊框框時,修改狀態(tài)為可拖拽。檢測鼠標(biāo)移動,根據(jù)鼠標(biāo)移動來修改框框位置。當(dāng)鼠標(biāo)放開時,修改狀態(tài)為不可拖拽。

  不多說,上代碼:

  [html] view plaincopyprint?

  

  

  

  

  

  

  

  

  

 

  

 

  

  

  

  右鍵自定義菜單

  總體思路:屏蔽瀏覽器郵件菜單,將自己寫的菜單隱藏,當(dāng)檢測到右鍵點(diǎn)擊時顯示菜單,否則隱藏菜單。

  上代碼:

  [html] view plaincopyprint?

  

  

  

  

  

  

  

  

  

 

  

  

  

  判斷一個域名是不是xx公司的

  (備注:該公司所有域名為***.xx.com,或xx.com)

  思路:正則判斷

  [javascript] view plaincopyprint?

  var exp = new RegExp(/^(.+\.)*qq.com(\W[\s\S]*$|$)/);

  var hostName = window.location.hostname;

  exp.test(hostName);

  文章高頻詞檢索

  說明:英文文章

  思路:用空格分割成數(shù)組,注意分隔符(引號,句號等),將單詞轉(zhuǎn)化為小寫作為key值,存進(jìn)hash數(shù)組,最后統(tǒng)計(jì)。

  代碼不上了,寫的太丑。

  高精度加法

  說明:兩個數(shù)相加,這兩個數(shù)非常大(接近Number.MAX_VALUE),求相加后的結(jié)果。

  思路:字符串輸入,字符串輸出,從低位到高位,一位位相加,注意進(jìn)位。

  代碼同樣不上了。

  主觀問題:

  主觀問題是仁者見仁智者見智的,這里只是提供一點(diǎn)參考。需要提醒的是,這部分一般是人力面,而人力一般不懂多少技術(shù),所以就不要抓著技術(shù)大談特談了

  自我介紹

  這個就不用我說了,時間不是重點(diǎn),但要盡量涵蓋所有時間軸。

  你從之前的學(xué)習(xí)/做項(xiàng)目中,學(xué)到了什么?

  能說出來就行,不需要太具體,比如學(xué)到了原型繼承blabla的,HR會很郁悶的

  你想在之后的工作中學(xué)到什么?

  你覺得你能學(xué)到什么就說什么吧,團(tuán)隊(duì)協(xié)作能力,交際能力,都是可以的

  你對工作地點(diǎn)、部門有什么要求?

  看你自己咯

  你覺得你最大的優(yōu)點(diǎn)和缺點(diǎn)是什么?

  回答”我最大的優(yōu)點(diǎn)就是沒有缺點(diǎn),我最大的缺點(diǎn)就是沒有缺點(diǎn)“這種作死的就沒必要去參加面試了。

  優(yōu)點(diǎn)要說實(shí)話,但可以挑好的說,比如優(yōu)點(diǎn)可以說自己善良什么的,不需要具體,比如你說優(yōu)點(diǎn)是人走關(guān)燈之類的就沒必要了(可以往大說環(huán)保意識強(qiáng))

  缺點(diǎn)可以說實(shí)話,但要保留,并且要善于將缺點(diǎn)描述轉(zhuǎn)化為優(yōu)點(diǎn)描述

http://m.ardmore-hotel.com/

【web前端面試題】相關(guān)文章:

Web前端面試題目及答案09-26

Web前端工作總結(jié)02-08

web前端面試技巧07-19

web前端開發(fā)求職簡歷01-18

web前端自我介紹07-04

Web前端工作總結(jié)8篇02-08

web前端開發(fā)的自我評價簡歷模板07-18

web前端開發(fā)求職簡歷4篇01-18

web前端工程師簡歷范文03-02