国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端筆試題面試題記錄(上)

Caizhenhao / 2590人閱讀

摘要:后續前端筆試題面試題記錄下小結我想說的是在找工作期間,肯定有自己發揮不好,或者不會的問題,一定要在晚上的時候自己再學習總結一下,在一個問題上面盡量不要栽倒兩次,學到了的才是自己的。

前言

過完元宵,就到上海找了波工作,現在已經入職好了,蹭波熱點,寫一波面試記錄,內容包含筆試題和面試題,還有一些沒有寫進來,準備再開一篇,許久沒寫了,寫的確實有些慢。如果喜歡的話可以點波贊,或者關注一下,希望大家看完本文可以有所收獲。

個人博客了解一下:obkoro1.com
后續

前端筆試題面試題記錄(下)

Q:什么情況下會碰到跨域問題?有哪些解決方法?

跨域問題是這是瀏覽器為了安全實施的同源策略導致的,同源策略限制了來自不同源的document腳本,同源的意思就是兩個URL的域名、協議、端口要完全相同。

script標簽jsonp跨域、nginx反向代理、node.js中間件代理跨域、后端在頭部信息設置安全域名、后端在服務器上設置cors。

Q:如何判斷一個變量是對象還是數組?

判斷數組和對象分別都有好幾種方法,其中用prototype.toString.call()兼容性最好。

function isObjArr(value){
     if (Object.prototype.toString.call(value) === "[object Array]") {
            console.log("value是數組");
       }else if(Object.prototype.toString.call(value)==="[object Object]"){//這個方法兼容性好一點
            console.log("value是對象");
      }else{
          console.log("value不是數組也不是對象")
      }
}

ps:千萬不能使用typeof來判斷對象和數組,因為這兩種類型都會返回"object"。

Q:定時器的執行順序或機制。

這個問題還是挺經常被問到的,有一些會直接問定時器的機制,有一些是通過筆試題的方式問執行順序然后問我為什么是這樣。

長話短說,我們需要記住的是:因為js是單線程的,瀏覽器遇到setTimeout或者setInterval會先執行完當前的代碼塊,在此之前會把定時器推入瀏覽器的待執行事件隊列里面,等到瀏覽器執行完當前代碼之后會看一下事件隊列里面有沒有任務,有的話才執行定時器的代碼。 所以即使把定時器的時間設置為0還是會先執行當前的一些代碼。

上面是我寫的一個栗子,如果還不清楚的話,大家可以找一篇關于定時器機制的詳解文章來看看。

Q:html中title屬性和alt屬性的區別?

這個問題被問了一次,當時我只記得,alt屬性是用于img標簽的,當圖片失效的時候會出現alt屬性里面的內容,title用來標記頁面的title,當時面試官問我還有沒有其他的區別。我。。。

然后我就找了一篇文章來看,漲了點姿勢:

1.
//1.當圖片不輸出信息的時候,會顯示alt信息 鼠標放上去沒有信息,當圖片正常讀取,不會出現alt信息
2.
// 2.當圖片不輸出信息的時候,會顯示alt信息 鼠標放上去會出現title信息
//當圖片正常輸出的時候,不會出現alt信息,鼠標放上去會出現title信息

另外還有一些關于title屬性的知識:

title屬性可以用在除了base,basefont,head,html,meta,param,script和title之外的所有標簽
title屬性的功能是提示。額外的說明信息和非本質的信息請使用title屬性。title屬性值可以比alt屬性值設置的更長
title屬性有一個很好的用途,即為鏈接添加描述性文字,特別是當連接本身并不是十分清楚的表達了鏈接的目的。
Q:標準盒子模型與IE怪異盒子模型

這個問題主要會出現在筆試題上面,比如:

這個盒子在w3c標準盒子模型和IE的怪異盒子模型下面它的寬度分別是多少?

標準盒子模型:總寬度=content100px+border 10px*2+padding 10px*2 //140px
怪異盒子模型: 總寬度=content60px+ border 10px*2+padding 10px*2 //100px

ps:

box-sizing: content-box || border-box;//css3 box-sizing設置為border-box將使用怪異盒子模型
當怪異盒子的寬度小于border+padding的寬度的時候,content width將變為0,盒子的寬度會被border和padding的總寬度撐開
ES5的繼承和ES6的繼承有什么區別?

ES5的繼承時通過prototype或構造函數機制來實現。ES5的繼承實質上是先創建子類的實例對象,然后再將父類的方法添加到this上(Parent.apply(this))。

ES6的繼承機制完全不同,實質上是先創建父類的實例對象this(所以必須先調用父類的super()方法),然后再用子類的構造函數修改this

具體的:ES6通過class關鍵字定義類,里面有構造方法,類之間通過extends關鍵字實現繼承。子類必須在constructor方法中調用super方法,否則新建實例報錯。因為子類沒有自己的this對象,而是繼承了父類的this對象,然后對其進行加工。如果不調用super方法,子類得不到this對象。

ps:super關鍵字指代父類的實例,即父類的this對象。在子類構造函數中,調用super后,才可使用this關鍵字,否則報錯。

Q:CSS3有哪些新增的屬性?
這里可以分為邊框、背景,漸變,陰影、2D轉換 3D轉換等之類的來說。
比如:邊框(border-radius、border-shadow、border-image)之類的 。

具體的可以參見菜鳥教程:鏈接。類似的鏡像問題還有HTML5的新增屬性,可以自己谷歌一下。

Q:你知道哪些http狀態碼?
1xx:1開頭的是信息狀態碼
2xx:2開頭的是請求成功
3xx:3開頭的是重定向
4xx:4開頭的是客戶端錯誤
5xx:5開頭的是服務器錯誤

這個問題并不難,在筆試面試都有碰到過,巧的是之前我就總結過一篇類似的文章。

Q:如何對一個數組去重?

這個問題出現了好幾次,而且很多面試官不滿足你只給出一兩種方法。

1、Set結構去重

這是ES6 提供了新的數據結構 Set。它類似于數組,但是成員的值都是唯一的,沒有重復的值。

let unique= [...new Set(array)];
//es6 Set數據結構類似于數組,成員值是唯一的,有重復的值會自動去重。
//Set內部使用===來判斷是否相等,類似"1"和1會兩個都保存,NaN和NaN只會保存一個

2、遍歷,將值添加到新數組,用indexOf()判斷值是否存在,已存在就不添加,達到去重效果。

    let a = ["1","2","3",1,NaN,NaN,undefined,undefined,null,null, "a","b","b"];
    let unique= arr =>{
         let newA=[];
        arr.forEach(key => {
           if( newA.indexOf(key)<0 ){ //遍歷newA是否存在key,如果存在key會大于0就跳過push的那一步
             newA.push(key);
           }
        });
        return newA;
    }
    console.log(unique(a)) ;//["1", "2", "3", 1, NaN, NaN, undefined, null, "a", "b"]
//ps:這個方法不能分辨NaN,會出現兩個NaN。是有問題的,下面那個方法好一點。

3、遍歷,將數組的值添加到一個對象的屬性名里,并給屬性賦值,對象不能添加相同屬性名,以這個為依據可以實現數組去重,然后用Object.keys(對象)返回這個對象可枚舉屬性組成的數組,這個數組就是去重后的數組。

    let a = ["1", "2", "3", 1,NaN,NaN,undefined,undefined,null,null, "a", "b", "b"];
    const unique = arr => {
        var obj = {}
        arr.forEach(value => {
            obj[value] = 0;//這步新添加一個屬性,并賦值,如果不賦值的話,屬性會添加不上去
        })
        return Object.keys(obj);//`Object.keys(對象)`返回這個對象可枚舉屬性組成的數組,這個數組就是去重后的數組
    }
    console.log(unique(a));//["1", "2", "3", "NaN", "undefined", "null", "a", "b"]
注意:

這個方法會將 number,NaN,undefined,null,變為字符串形式,因為對象的屬性名就是一個字符串,根據需求來吧,想想還是Set去重最簡單也最有效。

Q:垂直居中有哪些方法?

單行文本的話可以使用height和line-height設置同一高度。

position+margin:設置父元素:position: relative;,子元素height: 100px; position:absolute;top: 50%; margin: -50px 0 0 0;(定高)

position+transform:設置父元素position:relative,子元素:position: absolute;top: 50%;transform: translate(0, -50%);(不定高)

百搭flex布局(ie10+),設置父元素display:flex;align-items: center;(不定高)

類似的還有很多,實際應用中,可能就會使用一兩種方法,有興趣的可以看下這篇文章

Q:翻轉一個字符串

這個問題主要在筆試題碰到的多,思路就是先將字符串轉成一個數組,然后用數組的reverse()+join()方法。

let str="hello word";
let b=[...str].reverse().join("");//drow olleh
后續

前端筆試題面試題記錄(下)

小結

我想說的是:在找工作期間,肯定有自己發揮不好,或者不會的問題,一定要在晚上的時候自己再學習總結一下,在一個問題上面盡量不要栽倒兩次,學到了的才是自己的。

以上就是近期面試遇到的一些問題記錄總結,實際上還是有一些問題沒有寫出來,許久沒有寫文章了,寫的很慢,有點累。先給自己立一個flag,下周再寫一篇出來。希望各位大佬看了本文,能有所收獲,感謝閱讀。

最后:如需轉載,請放上原文鏈接并署名。碼字不易,感謝支持!本人寫文章本著交流記錄的心態,寫的不好之處,不撕逼,但是歡迎指點。然后就是希望看完的朋友點個喜歡,也可以關注一下我。
個人blog and 掘金個人主頁

以上2018.3.18

參考鏈接:

title與alt的區別

CSS-標準盒模型 & 怪異盒模型

常見的js算法面試題收集,es6實現

CSS垂直居中的11種實現方式

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/93499.html

相關文章

  • 前端記錄

    摘要:后續前端筆試題面試題記錄下小結我想說的是在找工作期間,肯定有自己發揮不好,或者不會的問題,一定要在晚上的時候自己再學習總結一下,在一個問題上面盡量不要栽倒兩次,學到了的才是自己的。 前言 過完元宵,就到上海找了波工作,現在已經入職好了,蹭波熱點,寫一波面試記錄,內容包含筆試題和面試題,還有一些沒有寫進來,準備再開一篇,許久沒寫了,寫的確實有些慢。如果喜歡的話可以點波贊,或者關注一下,希...

    wind3110991 評論0 收藏0
  • 前端記錄(下)

    摘要:前言接上篇前端筆試題面試題記錄上。默認值,不脫離文檔流,,,,等屬性不生效。。不脫離文檔流,依據自身位置進行偏離,當子元素設置,將依據它進行偏離。。 前言 接上篇前端筆試題面試題記錄(上)。趁清明小長假,把上篇剩下的部分也寫一下,因為最近比較忙這篇已經拖了很久了。現在剛剛開始銀四了,應該還是有些小伙伴在找工作,時間還不算太晚,希望本篇可以幫到這些小伙伴。 個人博客了解一下:obkoro...

    Lin_YT 評論0 收藏0
  • 前端記錄(下)

    摘要:前言接上篇前端筆試題面試題記錄上。默認值,不脫離文檔流,,,,等屬性不生效。。不脫離文檔流,依據自身位置進行偏離,當子元素設置,將依據它進行偏離。。 前言 接上篇前端筆試題面試題記錄(上)。趁清明小長假,把上篇剩下的部分也寫一下,因為最近比較忙這篇已經拖了很久了。現在剛剛開始銀四了,應該還是有些小伙伴在找工作,時間還不算太晚,希望本篇可以幫到這些小伙伴。 個人博客了解一下:obkoro...

    suemi 評論0 收藏0

發表評論

0條評論

Caizhenhao

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<