你可能需要的網易前端三輪面經

關注若川視野, 回復"pdf" 領取資料,回復"加群",可加群長期交流

前言

最近一個星期面了幾家公司,最后收獲了心儀的網易有道offer,于是推掉了其他的面試,至于一些其他大廠,并沒有投簡歷,由于種種原因(就是菜),準備目前先踏實的學吧。

希望大家秋招順利,成為offer收割機。

最有意思的就是網易有道第三輪技術面試,因為這個沒有具體的答案,有興趣的可以看看,我就先把這個第三輪面試場景題拿出來吧,其他的一些基礎的話,自己可以過一遍。

網易有道

三面

第三輪面試的是一個小哥哥,面試全程大概70分鐘,本來是遠程面試的,但是因為聲音的問題,所以選擇的就是電話面試了,小哥哥也挺好的,給我感覺就是很厲害的感覺,確實,接下來的問題,我就知道不簡單了。

第一個場景問題

比如直播的場景,你應該知道吧,你需要實現一個這樣子的場景,比如某個老師點擊某個地方,比如U盤,你這個時候需要展示U盤的動畫效果,比如這個時候,老師點擊這個電腦屏幕,你需要展示一個小電腦的動畫效果,向上述這樣子,「需要在特定的時間點,完成特定的動畫效果」

  • 嗯,這個問題,我的想法是,動畫是例外加上去的,如果說是直接后期處理的話,那應該跟我們前端的關系不大了,所以我們接下來的問題,就是如何去處理,時間同步的問題,怎么在具體的時間點,開始展示動畫呢

  • 第二個問題,假設我們可以獲取到某個時間點的動畫,那么接下來,小哥哥,給我們提出了一個新的問題,就是當你的網絡擁塞時,比如有延遲的時候,這個時候,出現卡頓的效果,原本需要5秒播放完的,可能需要7秒,那么你是如何去解決動畫同步的?

嗯,我沒有做過這種類似的問題,所以回答起來感覺很吃力,有了解的小伙伴可以評論留下你們的答案,我虛心學習。

第二個場景問題

有一個場景,在一個輸入框輸入內容,怎么更加高效的去提示用戶你輸入的信息,舉個例子,你輸入天貓,那么對應的提示信息是天貓商城,天貓集團,這個信息如何最快的獲取,有沒有不需要發請求的方式來實現?

  • 比如數據請求的時候,盡量發的請求少,那么可以做防抖和節流處理

  • 接下來的小哥哥,給了新的場景,當你的服務器掛了,數據取不到,那如何設計一個小型的本地數據庫

  • 接下來問題就是如何設計一個本地的數據,優化的點,就是盡可能的快,每次查詢數據盡可能的快

  • 我的第一個思路,是key-value這樣子去設計,但是隨后就被小哥哥給質疑出問題了,舉個例子,如果按照你的想法,如果關鍵字為 天貓,這樣子設計數據的話,就會存在被數據重復,這樣子顯然是不合理的。

  • 想了很久,這個時候,既然有前綴重合的情況,那么是不是有一種數據結構可以解決這個問題呢??

  • 字典樹,我們可以在本地建立一個預讀的字典樹,這樣子的話,根據用戶輸入的內容,查字典樹,這個時間復雜度大概就是O(m+n),所以很大程度上加快了查找效率。

當然了,有更好的解決辦法的話,可以留下你們的答案,看看你們是如何解決問題的。

第三個場景問題

Git版本工具你使用過吧,那你能不能實現一個這樣子的效果,完成Git Diff算法,比較兩個文件的不同,然后說一說具體的思路,這個過程怎么去比較的?兩個文件不同的位置如何標注出來,如何找出這個不同,具體說一說思路。

  • 一開始我想的是diff算法,比如是vue中的虛擬dom算法,但是感覺不對啊,diff是做了優化的,這里很明顯不合理,于是這個方法就不合理了。

  • 那么兩個文件,該如何快速的找到對應的兩者文件的差別呢?這個問題想了好久,嗯,當時自己好像是口胡了一些思路,比如去逐行逐行的比較,這樣子的話,其實也不是很合理的,仔細想一想不行

  • 小哥哥提示了我,我們是不是要去找最長的公共子串,這個是時候,我應該想起來這個是兩個串的LCS,應該就是經典的動態規劃問題,最后一個問題,確實沒有想到這個,可能就是很久沒有接觸這類動態規劃問題了。

  • 核心應該是動態規劃解決LCS,以及后續的處理,可以去看看有些文章,寫的很不錯,我這里就不張開啦。

Git是怎樣生成diff的:Myers算法

嗯,三面的話,考察的是你思考問題,以及結合問題是如何分析,可能也考了算法吧,嗯,害,挺難的。

一面

面試流程50分鐘,基本上自我介紹,我花了一分鐘介紹完自己在校經歷,接下來就是提問環節。

全程下來小哥哥耐心指點,非常溫柔,這就是我現象中的面試官應該有的樣子,還會耐心去提示你,有問題的話,也就幫助你,引導你怎么去回答。

H5新特性

簡歷上面寫了這個內容,所以被問到了,害,當時腦子一蒙,都完全沒有答好,這里在好好的梳理一遍?

  1. 本地存儲特性

  2. 設備兼容特性 HTML5提供了前所未有的數據與應用接入開放接口

  3. 連接特性 WebSockets

  4. 網頁多媒體特性 支持Audio Video SVG Canvas WebGL CSS3

  5. CSS3特性

增加拖放API地理定位SVG繪圖canvas繪圖Web WorkerWebSocket

然后我答了本地存儲,接下來就問我這方便的問題啦?

localstroge sessionstoge 區別 應用場景

vue組件間通信

好幾次面試都問了這個問題,這個問題我是這么看待的,取決于你平時項目中經常使用的方式是哪些,所以我每次都會答三種方式,反而網上8種組件間通信的方式,我記不住,也覺得了解一下即可,跟面試官交流一下,你在項目種是如何使用的即可。

遍歷對象方法

  • for in ?遍歷的也可以,不過對于非繼承的屬性名稱也會獲取到,通過hasOwnproperty判斷

  • Object.keys() ?可枚舉屬性和方法名

  • Object.getOwnPropertyNames() 可以獲取數組內包括自身擁有的枚舉或不可枚舉屬性名稱字符串,如果是數組的話,還有可能獲取到length屬性

編程題?

數組去重

常規題,講清楚思路,最后小哥哥提示能不能使用O(n),我給出了兩者方案

  • Set

  • 用對象特性,我覺得他就是想考這個,給你們貼一個代碼吧?

let unique = arr => {let obj = {}return arr.filter((ele) => {return obj.hasOwnProperty(typeof ele + ele) ? false : (obj[typeof ele + ele] = true)})}

數組的扁平化

let flatArr = (arr) => {return arr.reduce((res, ele) => {if(Object.prototype.toString.call(ele).slice(8,-1) === 'Array') {return [...res, ...flatArr(ele)]}else{return [...res, ele]}},[])}let arr = [1,2,3,[2,3,4,5]];console.log(flatArr(arr))

當然了,實現的方式有很多種,看你自己怎么去實現它了,最簡單的就是去遞歸對象。

深度遍歷

const tree = {name: 'root',children: [{name: 'c1',children: [{name: 'c11',children: []		},{name: 'c12',children: []		}]},{name: 'c2',children: [{name: 'c21',children: []		},{name: 'c22',children: []		}]}]
}// 深度優先的方式遍歷 打印 name
// ['root', 'c1','c11', 'c12', 'c2', 'c21', 'c22']

這題,我一開始想到的就是遞歸的寫法,寫完之后,然后小哥哥問了我遞歸的缺點,以及如何去優化,不用遞歸的方法該怎么去實現?

面試的時候,沒有寫出來,太緊張了,不在狀態,復盤的時候,寫了一下用「棧」的實現方式?

function solve(root) {let stack = [],result = [];if(!root) return [];stack.push(root)while(stack.length) {let node = stack.pop()if(node == null ) continueresult.push(node.name)for(let i = node.children.length-1; i >= 0; i--) {// 這里就是面試的重點,應該從后面的節點壓入棧中stack.push(node.children[i])}}return result}

鏈表的相加問題?

這個是LeetCode上面的題目,我好像還寫過,面試的最后一題的時候,我以及蒙了,完全不知道自己在干嘛,其實「鏈表題都是套路」,我連套路都沒有掌握,

這個我寫了一個專題,把題目刷完之后,應該遇到鏈表問題,可以輕松解決了。

「算法與數據結構」鏈表的9個基本操作

二面

大概的時間上的安排,算了一下,大致上是花了50分鐘吧,是個小姐姐,小姐姐好溫柔,我印象中小姐姐很nice,我記得我筆試做Promise的時候,我做錯了,她還特意問了我一遍,當時我大概知道錯了,不過呢,這個過程小姐姐是微笑的,緩解了尷尬,而且還耐心的去指導我,給她點贊呀。

ES6語法,Promise了解嗎

const promise = new Promise((resolve, reject) => {console.log(1);resolve();reject()console.log(2);})promise.then(() => {console.log(3);},() => {console.log("失敗的狀態")})console.log(4);

我看到以后,就直接說答案了,這點不好,因為一般而言,面試官出的題目肯定有點小坑,下次要注意了,最后面試官小姐姐還是微笑的告訴我,應該這么去做,然后怎么怎么樣。

聊一聊map和set

這個我是跟她說了用法,以及它們之間的區別,也就是它們經常使用的場景是哪些。

順便的話,就聊了一下Weakmap,然后這里的難點也不是很多,就是你的明白它們兩者數據結構的區別是啥,舉個例子說明情況即可。

前端性能優化

這個問題太大了,而且對于一個實際開發經驗為0的而言,這個問題就很置命,所以呢,我就準備了從URL到頁面渲染這個一塊去說,里面的優化點挺多的,可以自行去了解。

  • 構建請求行

  • 查緩存 (重點說一說)

  • dns解析(如何優化)

  • tcp http (比如減少請求次數,嗯,應該還有其他優化吧,cdn?)

  • 瀏覽器渲染過程 (這里面就有優化了,比如常見的如何避免回流和重繪)

  • 防抖和節流處理

  • webpack打包優化也可以說一說,前提你得有自信

其他問題

這場面試的話,給我的感覺就是,并不是跟面經一樣,問一些標準的答案,反而更多是跟你交流技術上的問題,比如,你遇到的問題,是如何去解決的。小姐姐還提到了,如果需要你做技術上的分享,你覺得你有哪些技術上的分享是可以跟團隊分享的。

好尷尬,我一個實習生,我感覺我最近研究的是webpack打包上面的問題,以及會的都是寫基礎的內容,所以多多少少的話,我也把我的觀點表達清楚了,表示我愿意去學習,愿意去分享這個技術。


其他面經

這里面就是其他一些公司的問題了,比如有贊,涂鴉等,問題很基礎,所以我帶過了,主要是覺得簡單,所以就掉過啦。

你說你最近在研究webpack,說一說

這個問題,我介紹的時候,就直接說了,最近在寫博客以及研究webpack,講一講webpack一些配置,比如loader,plugins,常見的loader,自己配過loader的話,答起來就很流暢。

然后順便叫我說一說原理,這我暫時就不清楚了。

ES6了解嗎,說一說

嗯,就按照你平常的來說,比如箭頭函數,展開運算符,Promise,然后好像就說了這三個….太緊張了

其實還有很多都用過,這里記錄一下

  • ES6類 Class

  • for...of 和 for...in

  • 對象的解構

  • rest操作符 / Spread操作符

  • 模板字符串

  • const let

閉包

嗯,這個問題,老生常談的問題了,就過吧,不同的人,對這個有不一樣的理解。

某知音科技

面試長達80分鐘,我覺得我都快要被問倒了,真的,這個過程太長了呀,不過呢,這個小哥哥也非常nice,過程中有非常認真聽我講,嗯,聽我一個人在那么巴拉巴拉半天。

  • 原型

  • 閉包

  • 作用域

  • 輸入url過程整個過程

  • https區別,TLS握手

  • 瀏覽器緩存

  • https如何保證安全,TLS握手的過程聊一聊

  • vue通信方式

  • vue數據響應式的原理,數組是怎么重寫的

以上的答案,就不梳理了,我之前的寫的博客都有涉及了,所以,好好準備的話,其實是沒有多大的問題的。

可以看看我之前梳理的,基本上真的全部覆蓋了?

推薦閱讀

我在阿里招前端,我該怎么幫你?(文末有福利)
如何拿下阿里巴巴 P6 的前端 Offer
如何準備阿里P6/P7前端面試--項目經歷準備篇
大廠面試官常問的亮點,該如何做出?
如何從初級到專家(P4-P7)打破成長瓶頸和有效突破
若川知乎問答:2年前端經驗,做的項目沒什么技術含量,怎么辦?
若川知乎高贊:有哪些必看的 JS庫?

末尾

你好,我是若川,江湖人稱菜如若川,歷時一年只寫了一個學習源碼整體架構系列~(點擊藍字了解我)

  1. 關注若川視野,回復"pdf" 領取優質前端書籍pdf,回復"加群",可加群長期交流學習

  2. 我的博客地址:https://lxchuan12.gitee.io?歡迎收藏

  3. 覺得文章不錯,可以點個在看呀^_^另外歡迎留言交流~

小提醒:若川視野公眾號面試、源碼等文章合集在菜單欄中間【源碼精選】按鈕,歡迎點擊閱讀,也可以星標我的公眾號,便于查找

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/276371.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/276371.shtml
英文地址,請注明出處:http://en.pswp.cn/news/276371.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PHP yii 框架源碼閱讀(一)

轉載鏈接:http://www.th7.cn/Program/php/2012/04/03/67983.shtml 目錄文件 |- framework 框架核心庫 |-|- base 底層類庫文件夾,包 含CApplication(應用類,負責全局的用戶請求處理,它管理的應用組件集,將提供特定功…

復習.net/c#時的小文章之萬年草稿版 (全是基礎概念,請懂的人繞行)

必讀文:61條面向對象設計的經驗原則(體會篇) C#知識點集合 (面試必備)一、顯式(explicit)轉換和隱式(implicit)轉換的一般概念int i 100; Response.Write(i); // 這就是隱式 Response.Write(i.ToString()); // 這就是顯式 一般來講&#xff…

timertask run函數未執行_圖執行模式下的 TensorFlow 2

文 / 李錫涵,Google Developers Expert本文節選自《簡單粗暴 TensorFlow 2.0》盡管 TensorFlow 2 建議以即時執行模式(Eager Execution)作為主要執行模式,然而,圖執行模式(Graph Execution)作為 TensorFlow 2 之前的主要執行模式&#xff0c…

AJAX自學筆記01

從今天開始正式系統學習asp.net ajax了。XMLHttpRequest對象屬性:Number readyState (返回值4表示完成)Function onreadystatechange (執行回調函數)string responseText (返回字符串型)XMLDocument responseXML(返回XML型&#x…

如何從 0 到 1 打造團隊 PC/H5 構建工具

關注若川視野, 回復"pdf" 領取資料,回復"加群",可加群長期交流學習一、前言 大家好,我叫鰻魚,這次分享的主題是如何從 0 到 1 打造適合自己的構建部署方案。image.png先例行的自我介紹,大概 14 年…

PHP yii 框架源碼閱讀(二) - 整體執行流程分析

轉載鏈接&#xff1a;http://tech.ddvip.com/2013-11/1384432766205970.html 一 程序入口 <?php// change the following paths if necessary $yiidirname(__FILE__)./http://www.cnblogs.com/framework/yii.php; $configdirname(__FILE__)./protected/config/main.php;/…

HTTP狀態碼大全

完整的 HTTP 1.1規范說明書來自于RFC 2616&#xff0c;你可以在http://www.talentdigger.cn/home/link.php?urld3d3LnJmYy1lZGl0b3Iub3JnLw%3D%3D在線查閱。HTTP 1.1的狀態碼被標記為新特性&#xff0c;因為許多瀏覽器只支持 HTTP 1.0。你應只把狀態碼發送給支持 HTTP 1.1的客…

testng接口自動化測試_Java+Maven+TestNG接口(API)自動化測試教程(10) 使用 Jenkins 構建自動化測試持續集成...

現在代碼可以運行了&#xff0c;但是每次運行都需要我們手工去執行&#xff0c;并且測試報告也只能在執行測試的電腦上才能看到&#xff0c;我們希望能夠定時自動執行測試&#xff0c;并且能夠做到自動發送測試報告到相關人員的電子郵箱中。Jenkins 正好可以很好的完成以上訴求…

sql數據類型詳解

BCD碼1字符1/2字節 ASC碼1字符1字節 GB2312碼1字符2字節 BIG5碼1字符5字節 (1)二進制數據類型 二進制數據包括 Binary、Varbinary 和 Image  Binary 數據類型既可以是固定長度的(Binary),也可以是變長度的。  Binary[(n)] 是 n 位固定的二進制數據。其中&#xff0c;n 的取…

論公眾號內卷

關注若川視野, 回復"pdf" 領取資料&#xff0c;回復"加群"&#xff0c;可加群長期交流學習曾幾何時公眾號文章的標題單純且沒有套路七年前的我就是這樣僅僅把公眾號當做一個寫文章的博客平臺甚至是像有道云一樣的在線筆記平臺當時的標題是這樣子滴《hashma…

PHP 利用Mail_MimeDecode類提取郵件信息

轉載鏈接:http://blog.csdn.net/laijingyao881201/article/details/5512693 重點為one_mail函數。利用Mail_mimeDecode類從郵件中提取郵件頭和郵件正文。 <?php header("content-type:text/html; charsetUTF-8"); /** record kid words and insert into databa…

【轉】概要設計說明書

概要設計說明書 一&#xff0e; 引言 1&#xff0e; 編寫目的 從該階段開發正式進入軟件的實際開發階段&#xff0c;本階段完成系統的大致設計并明確系統的數據結構與軟件結構。在軟件設計階段主要是把一個軟件需求轉化為軟件表示的過程&#xff0c;這種表示只是描繪出軟件的…

程序異常異常代碼: 0xc0000005_Java基礎:看完這篇你還怕碰到異常嗎?

前言在日常的開發以及平時的學習練習中&#xff0c;異常相信對于大家來講并不陌生&#xff0c;但是對于異常的具體使用、底層實現以及分類等等可能并不是很了解。今天我就抽出了一點時間系統的整理了異常的各個知識點&#xff0c;希望能夠幫助到大家對于Java 異常的理解與學習。…

寫給初中級前端工程師的進階指南

學習一門新技術的時候&#xff0c;最大的苦惱之一&#xff0c;大概就是不知道從何入手。典型的情況是&#xff0c;你大概知道學會以后&#xff0c;這門技術可以幫你解決什么問題。但是&#xff0c;怎么才能學會、循序漸進的學習路線是什么、學習范圍有多大的深度和廣度、涉及到…

同一頁面中引入多個JS庫產生的沖突解決方案(轉)

發生JS庫沖突的主要原因&#xff1a;與jQuery庫一樣&#xff0c;許多JS庫都使用‘$’符號作為其代號。因此在一個頁面中引入多個JS庫&#xff0c;并且使用‘$’作為代號時&#xff0c;程序不能識別其代表哪個庫&#xff08;這個是我自己的解釋&#xff0c;但更深的原因就必須深…

不用安裝Oracle Client如何使用PLSQL Developer

1. 下載oracle的客戶端程序包&#xff08;30M&#xff09;只需要在Oracle下載一個叫Instant Client Package的軟件就可以了&#xff0c;這個軟件不需要安裝&#xff0c;只要解壓就可以用了&#xff0c;很方便&#xff0c;就算重裝了系統還是可以用的。下載地址&#xff1a;http…

input file的默認value清空與賦值方法

轉載鏈接&#xff1a;http://www.jb51.net/article/24872.htm出于安全性考慮&#xff0c;JS是不能直接設置File的value值的&#xff0c;下面是我總結出來的方法第1個方法是大多人傳統做法&#xff0c;替換HTML代碼&#xff0c;樓上的已經用到了&#xff0c;我不過是用正則優化一…

python中o_Python I/O與進程的詳細講解

I/Owith語句with context_expression [as target(s)]:with-bodycontext_expression返回值遵從上下文管理協議&#xff0c;包含__enter__()與__exit__()方法&#xff0c;as語句的target(s)得到的是__enter__()返回值&#xff0c;執行with-body后會調用上下文管理器的__exit__()方…

千層套路 - Vue 3.0 初始化源碼探秘

關注若川視野, 回復"pdf" 領取資料&#xff0c;回復"1"&#xff0c;可加群長期交流學習劉崇楨&#xff0c;微醫云服務團隊前端工程師&#xff0c;左手抱娃、右手持家的非典型碼農。9 月初 Vue.js 3.0 正式發布&#xff0c;代號 "One Piece"。大秘…