成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

幾道前端面試題小記

tulayang / 428人閱讀

摘要:全局環(huán)境調(diào)用函數(shù)的對象實際為,所以函數(shù)內(nèi)的指向構(gòu)造函數(shù)通過構(gòu)造函造函數(shù)生成了一個新對象,指向這個新對象。學(xué)習(xí)前端一個月,上一周面試了大概多家,收獲的卻是寥寥。為了效率,前端各方面的內(nèi)容都有涉獵,深度卻相當(dāng)不足,面試時暴露各種問題。

最近面試了不少家,苦于前端經(jīng)驗薄弱,被各種血虐。做了不少家面試題,把各種不會的回來再做一遍,作為經(jīng)驗總結(jié)吧。

1.如何最優(yōu)性能去重一個數(shù)組?

方法有好多,比如新建一個數(shù)組,原數(shù)組的內(nèi)容依次往里放,若該數(shù)組元素已存在,則跳過;又或者先排序,依次比較前后兩個元素是否相等,若相等,則去掉刪除后一個元素。面試官有提到使用 filter 的方法,但是當(dāng)場沒想到,發(fā)現(xiàn)這個方法其實屬于相當(dāng)不錯的,這種函數(shù)式的思維在某些地方相當(dāng)實用。

var arr = [3,5,2,6,2,3,5,8,6]

function distinct(arr) {
    return arr.filter(function (elem,index,arr){
        return arr.indexOf(elem,index+1) === -1;
    });
}

console.log(distinct(arr));

思路擴(kuò)展
比如說存在一個數(shù)組,其中元素為對象,根據(jù)對象某個屬性進(jìn)行排序。例如將以下data數(shù)組按age正序排列,常規(guī)的辦法可能是通過比較age大小,操作對象來進(jìn)行排序,這樣代碼會比較復(fù)雜。而更優(yōu)的方法則是通過 sort 方法。

var data = [
{name:"xiaoming",age:18},
{name:"xiaohua",age:20},
{name:"xiaoli",age:25},
{name:"xiaozheng",age:16}];

查閱 MDN 關(guān)于 sort 方法,此方法明顯代碼量更少,含義更加清晰。

function asc_order(data){
    return data.sort(function (a,b){
        return a.age- b.age;
    })
}
2.變量聲明和函數(shù)聲明提升
function fn(a){
    console.log(a);
    var a=2;
    function a(){}
    console.log(a);
}
fn(1);

以上代碼輸出內(nèi)容?
此前看書時有了解到變量聲明會提升到作用域頂部,但忘記了變量賦值保持在原處,同時變量聲明和函數(shù)聲明的先后關(guān)系不確定,所以此題對我來說比較難,只能瞎蒙答案。

function  fn(a){
    var a;
    function a(){}
    console.log(a);
    a = 2;
    console.log(a);
}

fn(1);

所有全局變量都是window或Global的屬性

函數(shù)聲明會被提到范圍作用域的頂端

變量聲明被提到范圍作用域的頂端

變量聲明比函數(shù)聲明優(yōu)先級高,變量聲明優(yōu)于函數(shù)聲明,如果兩者同時存在,后被提升的函數(shù)聲明會覆蓋被提升的變量聲明

變量賦值不會被提升,到執(zhí)行行代碼才開始賦值

參考博客地址,根據(jù)以上五點共識,可將代碼翻譯如上所示。

深入思考
為什么JavaScript相比較其它語言會存在聲明提升?變量聲明時編譯器做了什么?變量賦值時編譯器又做什么了?

3.作用域和 this
var a = 10;
function test(){
    a = 100;
    console.log(a);
    console.log(this.a);
    var a;
    console.log(a);
}
test();
var a = 100;function test(){
    console.log(a);
    var a = 10;
    console.log(a);
}
test();
var a = 100;function test(){
    console.log(a);
    a = 10;
    console.log(a);
}

test();
console.log(a);

在非嚴(yán)格環(huán)境下,以上三個代碼分別輸出什么?碰到這種題目我也是頭暈眼花,稍有不慎就掉坑了。當(dāng)然實際業(yè)務(wù)中不會出現(xiàn)這樣的代碼,但還是相當(dāng)有必要以這樣的代碼來檢查對 JavaScript 理解的程度。
this 的用法參照阮一峰老師的博客,主要分為三種情況,但總的原則是指向調(diào)用函數(shù)的那個對象。

全局環(huán)境:調(diào)用函數(shù)的對象實際為 window ,所以函數(shù)內(nèi)的 this 指向 window ;

構(gòu)造函數(shù):通過構(gòu)造函造函數(shù)生成了一個新對象,this 指向這個新對象。

對象的方法:函數(shù)作為對象的某個方法調(diào)用, this 就指向這個上級對象。

故第一道題中屬于全局環(huán)境, this 指向 window ,所以輸出結(jié)果為:100,10,100;
第二道題輸出結(jié)果為:undefined,10;第三道題輸出結(jié)果為:100,10,10;

4.setTimeout 深入分析其機制
for (var i = 0;i<=3;i++){
    setTimeout(function (){
        console.log(i);
    },0);
}

此題輸出內(nèi)容是什么?

setTimeoutWindow 對象方法,用來注冊在指定的事件之后單次或重復(fù)調(diào)用的函數(shù)。

setTimeout的作用是將代碼推遲到指定時間執(zhí)行,如果指定時間為0,即setTimeout(f,0),那么會立刻執(zhí)行嗎?

答案是不會。因為上一段說過,必須要等到當(dāng)前腳本的同步任務(wù)和“任務(wù)隊列”中已有的事件,全部處理完以后,才會執(zhí)行setTimeout指定的任務(wù)。也就是說,setTimeout的真正作用是,在“消息隊列”的現(xiàn)有消息的后面再添加一個消息,規(guī)定在指定時間執(zhí)行某段代碼。setTimeout添加的事件,會在下一次EventLoop執(zhí)行。

setTimeout(f,0)將第二個參數(shù)設(shè)為0,作用是讓f在現(xiàn)有的任務(wù)(腳本的同步任務(wù)和“消息隊列”指定的任務(wù))一結(jié)束就立刻執(zhí)行。也就是說,setTimeout(f,0)的作用是,盡可能早地執(zhí)行指定的任務(wù)。而并不是會立刻就執(zhí)行這個任務(wù)。

所以最終的結(jié)果是當(dāng)前的函數(shù)執(zhí)行結(jié)束之后,再去執(zhí)行 setTimeout 定義的內(nèi)容。

5.class屬性覆蓋問題



XXXXXXXXXX

最后實際的問題是什么顏色?
存在多個類名時,類名的位置不會對屬性的渲染產(chǎn)生影響。只有在style中定義的位置才會有影響,同一條屬性,后面定義的會覆蓋前面定義的屬性。

6.實現(xiàn)類似 jquery 的 one 方法

即對一個元素綁定一個事件,操作一次后綁定事件失效。

HTML部分:


XXXXXXXXXX

JS部分:

window.onload = function(){
    var target = document.getElementById("target");
    function fn(e){
        alert("hello");
        target.removeEventListener("click",fn);
    };
    target.addEventListener("click",fn);
}

此代碼雖可行,但沒有進(jìn)行封裝,不便于使用。

正統(tǒng)封裝后的JS代碼,使用 arguments.callee 表示當(dāng)前 function ,同時需對 event 上的屬性有所了解。

function oneTime(node,type,callback){
    node.addEventListener(type,function (e){
        e.target.removeEventListener(e.type,arguments.callee);
        return callback(e);
    });
}
function handle(e){
    alert("hello!");
}
oneTime(p,"click",handle);

學(xué)習(xí)前端一個月,上一周面試了大概10多家,收獲的 offer 卻是寥寥。
為了效率,前端各方面的內(nèi)容都有涉獵,深度卻相當(dāng)不足,面試時暴露各種問題。
還是需深入思考,欲速則不達(dá)??!

大概是要加入大魚或者小悟,以后工作好好努力吧!

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/111579.html

相關(guān)文章

  • 幾道前端面試小記

    摘要:全局環(huán)境調(diào)用函數(shù)的對象實際為,所以函數(shù)內(nèi)的指向構(gòu)造函數(shù)通過構(gòu)造函造函數(shù)生成了一個新對象,指向這個新對象。學(xué)習(xí)前端一個月,上一周面試了大概多家,收獲的卻是寥寥。為了效率,前端各方面的內(nèi)容都有涉獵,深度卻相當(dāng)不足,面試時暴露各種問題。 最近面試了不少家,苦于前端經(jīng)驗薄弱,被各種血虐。做了不少家面試題,把各種不會的回來再做一遍,作為經(jīng)驗總結(jié)吧。 1.如何最優(yōu)性能去重一個數(shù)組? 方法有好多,比...

    yhaolpz 評論0 收藏0
  • 幾道前端面試小記

    摘要:全局環(huán)境調(diào)用函數(shù)的對象實際為,所以函數(shù)內(nèi)的指向構(gòu)造函數(shù)通過構(gòu)造函造函數(shù)生成了一個新對象,指向這個新對象。學(xué)習(xí)前端一個月,上一周面試了大概多家,收獲的卻是寥寥。為了效率,前端各方面的內(nèi)容都有涉獵,深度卻相當(dāng)不足,面試時暴露各種問題。 最近面試了不少家,苦于前端經(jīng)驗薄弱,被各種血虐。做了不少家面試題,把各種不會的回來再做一遍,作為經(jīng)驗總結(jié)吧。 1.如何最優(yōu)性能去重一個數(shù)組? 方法有好多,比...

    ChanceWong 評論0 收藏0
  • 前端最強面經(jīng)匯總

    摘要:獲取的對象范圍方法獲取的是最終應(yīng)用在元素上的所有屬性對象即使沒有代碼,也會把默認(rèn)的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個光禿禿的元素,方法返回對象中屬性值如果有就是據(jù)我測試不同環(huán)境結(jié)果可能有差異而就是。 花了很長時間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點個贊,點個star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項目地址 https:...

    wangjuntytl 評論0 收藏0
  • 前端經(jīng)典面試 不經(jīng)典不要star!

    摘要:前言上一期說好的的核心模塊進(jìn)階以及基本應(yīng)用的使用將在號或者號與大家見面在此之前我想跟大家分享幾個前端經(jīng)典的面試題為什么我突然想寫這么一篇文章呢今天我應(yīng)公司要求去面試了下幾位招聘者然后又現(xiàn)場整不出幾個難題就搜了一下前端變態(tài)面試題,前提我并不是 前言 上一期說好的node.js的核心模塊進(jìn)階以及基本web應(yīng)用的使用將在2號或者3號與大家見面,在此之前我想跟大家分享幾個前端經(jīng)典的面試題,為什...

    codergarden 評論0 收藏0

發(fā)表評論

0條評論

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