主頁 > 軟體設計 > 有空就來做兩道前端面試題題,你就是下一個大佬(總結篇)

有空就來做兩道前端面試題題,你就是下一個大佬(總結篇)

2021-10-08 08:54:10 軟體設計

來自專欄《前端面試題》

前言

?? 作者主頁:https://hongweblog.blog.csdn.net/

?? 簡介:沒有什么遠大的理想,做自己喜歡的事情就好~

?? 掃碼關注微信公眾號: >>> Dianc小助手 <<<

?? 前端學習路線圖、面試刷題、二次元壁紙珍藏,Dianc小助手后續會持續完善,

?? 大家的積極參與和討論,是Dianc推送更多優質內容的動力~

目錄

  • 前言
    • 時隔25天
    • 第一題
      • 解題思路
    • 第二題
      • 解題思路
    • 第三題
      • 解題思路
    • 第四題
      • 解題思路
    • 第五題
      • 解題思路
    • 第六題
      • 解題思路
    • 第七題
      • 解題思路
    • 第八題
      • 解題思路
    • 第九題
      • 解題思路
    • 第10題
      • 解題思路
    • 第11題
      • 解題思路
    • 第12題
      • 解題思路
    • 第13題
      • 解題思路
    • 第14題
      • 解題思路
    • 第15題
      • 解題思路
    • 第16題
      • 解題思路
    • 第17題
      • 解題思路
    • 第18題(CSS題目 - Beta)
      • 答案
    • 第19題
      • 解題思路
    • 第20題
      • 解題思路
    • 最后
  • 熱門文章推薦:


時隔25天

本期終于迎來總結,本篇有點特殊,前段時間因為js代碼不以圖片的形式展現,所以導致作業量變大,效果反而也不算很好,所以后面打算還是以圖片的形式發出,并且下一期的面試題將加入css/html的考點進行寫作,

本次還是以手寫代碼為主,小伙伴可以自行復制,同時因為每篇發布時間不統一,導致解題思路都不算很準確,如果小伙伴能及時發現,那么請及時指出,本人會及時修改~

第一題

<script>
        // 使用遞回的形式實作陣列的扁平化
        var a = [1, [2, [3, 4, 5]]]
        function flatten(arr) {
            let result = []
            for (var i = 0; i < arr.length; i++) {
                if (Array.isArray(arr[i])) {
                    result = result.concat(flatten(arr[i]))
                }
                else {
                    result.push(arr[i])
                }
            }
            return result;
        }
        console.log(flatten(a)); //[1,2,3,4,5]
    </script>

解題思路

首先要理解扁平化是什么意思,顧名思義就是減少復雜性裝飾,使其事物本身更簡潔、簡單,突出主題,即要把多余的嵌套去除,遞回判斷條件就是如果不是陣列那么結束,拋出答案,即扁平化的陣列,

第二題

<script>
        // 說出下面的列印結果,并解釋其原因

        let a = { n: 1 };
        let b = a;
        a.x = a = { n: 2 };

        console.log(a.x)
        console.log(b.x)
    </script>

解題思路

這一題涉及到賦值的優先級問題,a.x比等于號的賦值優先級高,所以會先將a.x賦值成{n:2},再將a的指標變成{n:2},所以原本a.x是有值的,后來再進行賦值時找不到,就會輸出undefined,

第三題

<script>
        // 說出下列的列印結果

        const obj = { 1: 'a', 2: 'b', 3: 'c' }
        const set = new Set([1, 2, 3, 4, 5])

        console.log(obj.hasOwnProperty('1'))
        console.log(obj.hasOwnProperty(1))
        console.log(set.has('1'))
        console.log(set.has(1))

    </script>

解題思路

hasOwnProperty() 方法會回傳一個布林值,指示物件自身屬性中是否具有指定的屬性(也就是,是否有指定的鍵,同時,物件里的屬性名默認是物件呈現,所以第一行應該輸出True,然后下面的has()方法指示Set物件是否包含指定的值,如果存在指定值,則回傳true,否則回傳false,
實列化后是會判斷是物件還是數字的,所以第三行輸出false,

第四題

<script>
        // 說出下列的列印結果

        const obj = { a: 'one', b: 'two', a: 'three' }
        console.log(obj)
    </script>

解題思路

這題簡單的不行,只要知道物件重復是會被頂替的就知道答案了,沒有太多坑,所以答案就是輸出
{a: ‘three’, b: ‘two’}

第五題

<script>
        // 說出下列的列印結果

        for (let i = 1; i < 5; i++) {
            if (i === 3) continue
            console.log(i)
        }
    </script>

解題思路

for回圈不用多說,這里區分好break和continue的區別就好,break是結束回圈,continue是跳出本次回圈,下一次還會執行,所以應該輸出1,2,4,

第六題

<script>
        // 說出下列的列印結果

        String.prototype.giveLydiaPizza = () => {
            return 'Just give Lydia pizza already!'
        }
        const userName = 'Lydia'
        console.log(userName.giveLydiaPizza())
    </script>

解題思路

String是一個內置的建構式,我們可以為它添加屬性, 我剛給它的原型添加了一個方法, 原始型別的字串自動轉換為字串物件,由字串原型函式生成, 因此,所有字串(字串物件)都可以訪問該方法!

第七題

 <script>
        // 說出下列的列印結果
        var result = [];
        var a = 3;
        var total = 0;
        function foo(a) {
            for (var i = 0; i < 3; i++) {
                result[i] = function () {
                    total += i * a;
                    console.log(total)
                }
            }
        }
        foo(1);
        result[0]();
        result[1]();
        result[2]();

    </script>

解題思路

首先我們一定看清楚回圈的變數是全域變數還是區域變數,如果是全域那么呼叫i的時候在預編譯時已經算好了,所以此時函式result呼叫到的i應該是3,所以再看total也是全域變數,所以執行后應該是3,6,9,

第八題

<script>
        // 說出下列的列印結果

        function Person(name) {
            this.name = name;
        }
        function Student() {

        }

        Student.prototype = Person.prototype;
        Student.prototype.constructor = Student;
        var s = new Student('Tom');
        console.log(s instanceof Person);
    </script>

解題思路

學了這么久js多多少少聽過是大寫的首字母一般作為建構式使用,所以使用instanceof 運算子用于檢測建構式的 prototype 屬性是否出現在某個實體物件的原型鏈上,
所以答案是true;

第九題

<script>
        for (var i = 0; i < 10; i++) {
            setTimeout(() => {
                console.log(i)
            }, 0)
        }
    </script>

解題思路

這一題很經典噢,只能說搞懂之后就很簡單,當存在setTimeout時,要明白它是下一次宏任務,然后又因為是var變數,所有呼叫的i應該是window.i=10,所以上述代碼列印10次10,

第10題

<script>
        for (let i = 0; i < 10; i++) {
            setTimeout(() => {
                console.log(i)
            }, 0)
        }
    </script>

解題思路

那么上面我已經提供了兩種方式了,這邊為了證明自己沒有水文章,我決定寫出第四種方法,大家可以自己深思一下噢,這個經典不止這幾種方式實作,

第11題

<script>
        console.log('a')

        setTimeout(() => {
            console.log('b')
        }, 0)

        console.log('c')

        Promise.resolve().then(() => {
            console.log('d')
        }).then(() => {
            console.log('e')
        })

        console.log('f')
    </script>

解題思路

好,先說答案:a c f d e b;

具體本題考察宏任務和微任務的執行順序,首先我們先了解一下宏任務和微任務的作業流程,其實昨天也涉及到了,但是沒有細說
在這里插入圖片描述
那么再來說說本題的宏任務是正常輸出的console.log,setTimeout屬于下一輪宏任務,即本輪微任務執行完再執行,Promise屬于微任務,那么setTimeout就是最后輸出的啦

第12題

<script>
        var a = 2
        var obj = {
            a: 3,
            fn: function () {
                const a = () => {
                    console.log(this.a)
                }
                const b = function () {
                    console.log(this.a)
                }
                a()
                b()
            }
        }

        obj.fn()
    </script>

解題思路

先說答案:3 2;

不知道小伙伴做對沒有,那么首先我們要知道這題考察this的指向問題,通過題目發現其實只有箭頭函式和正常函式的區別,那就要清楚箭頭函式的this其實指向的是父級作用域,所以this.a應該指向這個物件里的a,正常函式就不多說了,指向window,

第13題

<script>
        function side(arr) {
            arr[0] = arr[2];
        }
        function a(a, b, c = 3) {
            c = 10;
            side(arguments);
            return a + b + c;
        }

        console.log(a(1, 1, 1))
    </script>

解題思路

這題需要細心一點,首先我們執行console.log的時候會傳給a函式3個值,但是,這里注意一下,c=3說明獨立創建了一個塊級作用域,再往下看c又=10了,很好這里應該會有小伙伴被誤導了,arguments真的會參考c=10嗎,答案是錯的,其實當c獨立創建了一個塊級作用域的時候,arguments就不會取這個值了,而是取傳過來的值1,1,1,那么a和b應該都等于1,c不變等于10.

第14題

<script>
        var a = [0];
        if (a) {
            console.log(a == true);
        } else {
            console.log(a)
        }

        (function () {
            var a = (b = 5);
        })();

        console.log(b);
        console.log(a);
    </script>

解題思路

首先當一個變數在if里面的時候會轉化成布林值進行判斷ture或者false進行判斷,再進去之后a==true涉及到復雜型別,那么比較的就是指標指向,不同就為false,所以第一個值列印false,再往后看,立即執行函式里定義了一個var,那么在作用域里面,外面是訪問不到里面的,但是b可以訪問到,因為是全域變數,所以第二和第三個值就為5和【0】,a取開始定義的值,

第15題

<script>
        var fullName = 'a';
        var obj = {
            fullName: 'b',
            prop: {
                fullName: 'c',
                getFullName: function() {
                    return this.fullName;
                }
            }
        }

        console.log(obj.prop.getFullName());
        var test = obj.prop.getFullName;
        console.log(test());
    </script>

解題思路

首先這題考察this的指向,那么我們看清楚第一次控制臺輸出的時候函式是直接物件執行,所以第一次輸出的fullName應該指向父級prop的fullName,即c,
第二次并不是直接使用物件執行函式,所以應該翻譯成window.test();那么全域的fullName即是a,所以答案就出來了,

第16題

 <script>
        var foo = {
            bar: function() {
                return this.baz;
            },
            baz: 1
        }
        console.log(typeof(f = foo.bar)());
    </script>

解題思路

首先我們需要知道輸出的時候后面有(),說明要執行函式,此時我們發現f其實是全域的,所以呼叫起來應該是window.f(),那么foo.bar的this應該就指向window,往上找不到bar的屬性,所以應該輸出undefined,

第17題

<script>
        const num = {
            a: 10,
            add() {
                return this.a + 2;
            },
            reduce: () => this.a - 2
        };
        console.log(num.add());
        console.log(num.reduce());
    </script>

解題思路

add()函式輸出12應該沒什么問題,關鍵就在reduce輸出什么,仔細觀察會發現使用的并不是正常函式,而是箭頭函式,箭頭函式的this指向最近的父級,再往上看就只有window了,所以window.a是udefined,那么減去一個非數將得到NAN對吧,

第18題(CSS題目 - Beta)

說一下對css盒模型的理解

答案

css盒子模型 又稱框模型 (Box Model) ,包含了元素內容(content)、內邊距(padding)、邊框(border)、外邊距(margin)幾個要素,
盒模型有兩種:標準盒模型和IE盒模型,
標準盒模型中width和height指的是內容區域的寬度和高度,增加內邊距、邊框和外邊距不會影響內容區域的尺寸,但是會增加元素框的總尺寸;但在IE6瀏覽器的width不是內容的寬度,而是內容、內邊距和邊框的寬總和;IE的content部分包含了border和padding,

第19題

<script>
        let a = {
            name: "jock",
            age: 20
        }

        function change(o) {
            o.age = 24;
            o = {
                name: "alan",
                age: 30
            }
            return o
        }
        let b = change(a)
        console.log(b.age)
        console.log(a.age)
    </script>

解題思路

本題主要考察物件指標的參考關系,那么我們看后面將a的值傳給了change(o),所以此時o和a的物件指向同一個位置,所以a.age=o.age=24,后面又重新覆寫了o的物件,所以此時o.age變成了30.

第20題

<script>
        // TODO: A: foo(){foo=10;console.log(foo)}
        // TODO: B: 1
        // TODO: C: 10
        // TODO: D: undefined

        var foo = 1;
        (function foo() {
            foo = 10;
            console.log(foo);
        }())
    </script>

解題思路

注意這里的立即執行函式是有名稱的,本題主要考察有名稱的自定義函式會默認創建一個物件屬性值,而這個屬性值就是函式本身(是只讀的,不能被修改)所以答案就輸出這個函式

最后

其實大廠的題目有簡單也有難點,甚至有考細節的地方,就和年輕時考的數學試卷一樣,選擇題總有送分的對吧,所以簡單的題一定要拿下,但也不能掉以輕心,
如果上面的題目你還有不懂的建議參考解題思路去復習,查漏補缺,最后祝各位小伙伴都能進入自己理想的企業 !


來自《往期優質文章》

熱門文章推薦:

🥇 這樣配置學習VSCode,寫前端代碼想不快都難(??精心準備多動圖,建議收藏噢~??)
🥈 還不會搭建個人博客?手把手教你用Wordpress搭建只屬于你的世界~
🥉 Hexo的準備作業(手把手教你搭建Node.js/Git環境)

在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/306290.html

標籤:其他

上一篇:HCIE必經之路(二)——IPSec Over GRE綜合實驗

下一篇:一萬五千字詳解分治法(帶你用分治法思想優化程式,計算降低復雜演算法的時間復雜度)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more