Web前端初級工程師面試題

1、一個頁面上兩個div左右鋪滿整個瀏覽器,要保證左邊的div一直爲100px,右邊的div跟隨瀏覽器大小變化(好比瀏覽器爲500,右邊div爲400,瀏覽器爲900,右邊div爲800),請寫出大概的css代碼。javascript

 

1.使用flexcss

 

//htmlhtml

<div class='box'><div class='left'></div> <div class='right'></div></div>前端

 

 

//cssvue

.box {java

    width: 400px;nginx

    height: 100px;程序員

    display: flex;es6

    flex-direction: row;web

    align-items: center;

    border: 1px solid #c3c3c3;

}

.left {

    flex-basis:100px;

    -webkit-flex-basis: 100px;

    /* Safari 6.1+ */

    background-color: red;

    height: 100%;

}

.right {

    background-color: blue;

    flex-grow: 1;

}

 

2.浮動佈局

 

<div id="left">Left sidebar</div>

<div id="content">Main Content</div>

 

<style type="text/css">

{

    margin: 0;

    padding: 0;

}

#left {

    float: left;

    width: 220px;

    background-color: green;

}

#content {

    background-color: orange;

    margin-left: 220px;

    /*==等於左邊欄寬度==*/

}

</style>

 

2、請寫出一些前端性能優化的方式,越多越好

 

1.減小dom操做

2.部署前,圖片壓縮,代碼壓縮

3.優化js代碼結構,減小冗餘代碼

4.減小http請求,合理設置 HTTP緩存

5.使用內容分發cdn加速

6.靜態資源緩存

7.圖片延遲加載

 

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

 

輸入地址

1.瀏覽器查找域名的 IP 地址

2.這一步包括 DNS 具體的查找過程,包括:瀏覽器緩存->系統緩存->路由器緩存…

3.瀏覽器向 web 服務器發送一個 HTTP 請求

4.服務器的永久重定向響應(從 http://example.com 到 http://www.example.com)

5.瀏覽器跟蹤重定向地址

6.服務器處理請求

7.服務器返回一個 HTTP 響應

8.瀏覽器顯示 HTML

9.瀏覽器發送請求獲取嵌入在 HTML 中的資源(如圖片、音頻、視頻、CSS、JS等等)

10.瀏覽器發送異步請求

 

4、請大概描述下頁面訪問cookie的限制條件

 

  1. 跨域問題

  2. 設置了HttpOnly

 

5、描述瀏覽器重繪和迴流,哪些方法可以改善因爲dom操做產生的迴流

 

1.直接改變className,若是動態改變樣式,則使用cssText

 

// 很差的寫法

var left = 1;

var top = 1;

el.style.left = left + "px";

el.style.top = top + "px"; // 比較好的寫法

el.className += " className1";

 

// 比較好的寫法

el.style.cssText += ";

left: " + left + "px;

top: " + top + "px;";

 

2.讓要操做的元素進行」離線處理」,處理完後一塊兒更新

 

a) 使用DocumentFragment進行緩存操做,引起一次迴流和重繪;

b) 使用display:none技術,只引起兩次迴流和重繪;

c) 使用cloneNode(true or false) 和 replaceChild 技術,引起一次迴流和重繪

 

6、vue生命週期鉤子

 

1.beforcreate

2.created

3.beformount

4.mounted

5.beforeUpdate

6.updated

7.actived

8.deatived

9.beforeDestroy

10.destroyed

 

7、js跨域請求的方式,能寫幾種是幾種

 

一、經過jsonp跨域

二、經過修改document.domain來跨子域

三、使用window.name來進行跨域

四、使用HTML5中新引進的window.postMessage方法來跨域傳送數據(ie 67 不支持)

五、CORS 須要服務器設置header :Access-Control-Allow-Origin。

六、nginx反向代理 這個方法通常不多有人說起,可是他能夠不用目標服務器配合,不過須要你搭建一箇中轉nginx服務器,用於轉發請求

 

8、對前端工程化的理解

 

  • 開發規範

  • 模塊化開發

  • 組件化開發

  • 組件倉庫

  • 性能優化

  • 項目部署

  • 開發流程

  • 開發工具

 

九, js深度複製的方式

 

1.使用jq的$.extend(true, target, obj)

2.newobj = Object.create(sourceObj),// 可是這個是有個問題就是 newobj的更改不會影響到 sourceobj可是 sourceobj的更改會影響到newObj

3.newobj = JSON.parse(JSON.stringify(sourceObj))

 

10、js設計模式

 

整體來講設計模式分爲三大類:

 

  • 建立型模式,共五種:工廠方法模式、抽象工廠模式、單例模式、建造者模式、原型模式。

  • 結構型模式,共七種:適配器模式、裝飾器模式、代理模式、外觀模式、橋接模式、組合模式、享元模式。

  • 行爲型模式,共十一種:策略模式、模板方法模式、觀察者模式、迭代子模式、責任鏈模式、命令模式、備忘錄模式、狀態模式、訪問者模式、中介者模

 

11、圖片預覽

 

<input type="file" name="file" onchange="showPreview(this)" />

<img id="portrait" src="" width="70" height="75">

 

function showPreview(source) {

  var file = source.files[0];

  if(window.FileReader) {

      var fr = new FileReader();

      fr.onloadend = function(e) {

        document.getElementById("portrait").src = e.target.result;

      };

      fr.readAsDataURL(file);

  }

}

 

12、扁平化多維數組

 

一、老方法

 

var result = []

function unfold(arr){

     for(var i=0;iarr.length;i++){

      if(typeof arr[i]=="object" && arr[i].length>1) {

       unfold(arr[i]);

     } else {        

       result.push(arr[i]);

     }

  }

}

 

var arr = [1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]];

unfold(arr)

 

二、使用tostring

 

var c=[1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]];

var b = c.toString().split(',')

 

三、使用es6的reduce函數

 

var arr=[1,3,4,5,[6,[0,1,5],9],[2,5,[1,5]],[5]];

const flatten = arr => arr.reduce((a, b) => a.concat(Array.isArray(b) ? flatten(b) : b), []);

var result = flatten(arr)

 

十3、iframe有那些缺點?

 

  • iframe會阻塞主頁面的Onload事件;

  • 搜索引擎的檢索程序沒法解讀這種頁面,不利於SEO;

  • iframe和主頁面共享鏈接池,而瀏覽器對相同域的鏈接有限制,因此會影響頁面的並行加載。

  • 使用iframe以前須要考慮這兩個缺點。若是須要使用iframe,最好是經過javascript動態給iframe添加src屬性值,這樣能夠繞開以上兩個問題。

學習web前端到知海匠庫http://www.zhihaijiangku.com,讓你成爲一名優秀的程序員。

相關文章
相關標籤/搜索