文远知行前端面经 (社招资深)

一面(2022年2月21日):
中间挺多意外的:

  1. 自我介绍
  2. 介绍一下项目。

根据项目问了以下一些问题:

  1. 使用canvas过程中有没有进行一些优化。用了缓存canvas来减少一部分操作步骤,然后问了下如果缓存canvas过多怎么处理?这个没答上来,感觉有必要看一下Fabric的源代码(面试官想让我答LRU,但是每次重绘都要画一次画板,个人觉得做不到)。
  2. 然后问我还有没有其他项目要介绍的。我说了一下electron的IM,其中提到消息超过一定数量进行换页处理,保持页数在3页(问我为什么3页,我说因为1页的话,滚动一下又要加载,体验不是很好)。因为消息太多很容易卡。
  3. 同时提了一下builder项目里面的静态资源为什么用node处理的原因(因为node不适合处理大片的内存)。

之后就是:

  1. 你说一下js的原型,原型链,实例和构造函数之间的关系吧。
  2. 了解JS的继承吗?是怎么继承的?
  3. 作用域和作用域链,执行上下文和闭包。其中闭包和作用域以及执行上下文有什么关系?
  4. 了解common js 和es6的module吗?分别是什么?两者有什么区别?
  5. 你理解的模块化是什么?(分隔代码,方便管理。另外减少全局变量和函数命名冲突)。
  6. 用过webpack对吧,你理解中的webpack是什么来的?(讲了下webpack是打包器还有AST)
  7. 讲一下事件循环吧?宏任务有哪些?微任务有哪些?宏任务和宏任务之间就没有其他东西了吗(答了还有requestAnimationFrame和requestIdleCallback)?这边对于requestAnimationFrame每次都一定会执行不太确定,我答的是dom刷新才执行。
  8. 数组和链表的区别
  9. vue你比较熟是吧?想问下React和vue你觉得有什么区别?
  10. vue你用了这么久,那你觉得它有什么优点和缺点?
  11. vue是怎么实现更改数据之后就触发UI更新的?
  12. 虚拟dom有什么效果?
  13. 你谈到虚拟Dom可以去掉无效的状态,直接到达最终状态。那么如果我确实需要中间的状态呢?(this.$nextTick)
  14. vue的diff是怎么样的?复杂度多少?
  15. vue中的key有什么作用?如果不用key或者key使用数组的index,会有什么效果?
  16. http常用的头部有哪些?
  17. 浏览器缓存机制是怎么样的?(协商缓存和强缓存)。
  18. 做了两道题:写debounce和合并两个有序链表。

总结就是:
八股文复习不够充分。另外项目的一些点没有突出介绍,例如使用了单例模式,以及出于跨组件通信比较多而设计了时间总线之类的都没有说。

  1. 原型链这种东西还是不能很流畅的说出来。
  2. 事件循环或许需要复习一下背景还有更细节的一些内容。
  3. http有复习但是感觉复习的不够。例如协商缓存之类的。
  4. vue的diff算法和key的作用得重新看一下。
  5. js为什么出现??榛土街植煌哪?榈汲龇桨傅牟钜?。

二面(2月24日):
状态不好,简单题想不出来挂了。

  1. 自我介绍 balabala
  2. 做一道题(没做出来),题目如下:
// 编程题: 由'K'(人)和'O'(空地)组成的2D数据,请计算人群的数量。
// 在空地里,人群是通过垂直方向或者水平方向上相邻的人连接而成。
//
// 示例1
// 输入:
// OKKKO
// OKKKO
// OKKKO
// OKKOO
// 输出:1
// 
// 示例2:
// KKOOO
// KOOOO
// OKOKO
// KOOOO
// 输出:4

const data = [
  'OKKKO'.split(''),
  'OKKKO'.split(''),
  'OKKKO'.split(''),
  'OKKOO'.split('')
];

const data1 = [
  'KKOOO'.split(''),
  'KOOOO'.split(''),
  'OKOKO'.split(''),
  'KOOOO'.split('')
];

const data2 = [
  ['O', 'O'],
  ['K', 'K'],
  ['O', 'O'],
  ['K', 'O']
];

function walkGraphic (tdArr, map, x, y) {
  if (map[`${x},${y}`]) {
    return;
  }
  if (tdArr[x][y] !== 'K') {
    return;
  }
  map[`${x},${y}`] = true;
  if (tdArr[x - 1] && tdArr[x - 1][y]) {
    walkGraphic(tdArr, map, x - 1, y);
  }
  if (tdArr[x + 1] && tdArr[x + 1][y]) {
    walkGraphic(tdArr, map, x + 1, y)
  }
  if (tdArr[x][y + 1]) {
    walkGraphic(tdArr, map, x, y + 1);
  }
  if (tdArr[x][y - 1]) {
    walkGraphic(tdArr, map, x, y - 1);
  }
}

function getGroupNums (tdArr) {
  let groupNums = 0;
  const map = {};
  tdArr.forEach((arr, x) => {
    arr.forEach((item, y) => {
      if (item === 'K' && !map[`${x},${y}`]) {
        groupNums += 1;
        walkGraphic(tdArr, map, x, y);
      }
    });
  });
  return groupNums;
}

console.log(getGroupNums(data2));

问一下简单的问题

  1. 说一下vue3和vue2的区别
  2. worker是什么?service worker是什么?
  3. worker和网页其他内容共享内存吗?(因为是线程,应该是共享内存的)
  4. grpc是什么协议?grpc协议运行在网络模型第几层?(基于http2,所以应该是应用层)
  5. 用过nodejs吗?(写脚本和写过后端)
  6. 你用node写过后端,那么请问下你是怎么监控后端的运行情况的?异常监控,api调用,cpu和内存占用率这些。(不会)
  7. 项目中为什么有webpack还要用vite?

反问:

  1. 前端做什么的?
  2. 前端团队有多少人?
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容