美团前端一面面经

美团一面 (50 min) 已凉~~

发个面经保佑一面能过吧
顺序大概是

  1. 自我介绍

  2. 问了下项目中用到了响应式的适配,说了下用了 rem (然后没有追问,可能是想让我自己说)

  3. 项目中的首屏优化(路由懒加载,图片懒加载)

  4. 项目中有没有用到什么新技术说了下 vue3,然后提到了 proxy,问了 vue3 中响应式数据如何收集依赖

  5. 路由懒加载说了下 es6 的 import 函数以及需要分包

  6. 说了下图片懒加载的实现原理

  7. 图片懒加载中如何判断的图片快达到视口,说了三种

    • element.offsetTop - document.documentElement.scrollTop <= window.innerHeight
    • getBoundingClientRect
    • IntersectionObserver
  8. 项目的登录注册

  9. webpack 中 loader 和 plugin 区别

  10. 问了有没有了解其他构建工具,说了 vite 讲了讲(了解的不多)

    八股

  11. 响应状态码 100、101、200、301、302、304、403、404、500

  12. http2~http3

    开始问基础

  13. css 动画 (transition、animation)

  14. 举了个例子说用 js 一帧一帧绘制和用 css 动画哪个更优(因为不知道,从 cpu 和 gpu 方面来讲)

突然想起来,面试官应该是想考我关于浏览器渲染机制方面的问题(简历上写了),js 的执行会挂起 GUI 线程,如果使用 js 来绘制动画的话会阻塞 html 的解析导致渲染树构建被延迟。

后来去查了一下,关于这方面牵扯的还是挺多的,可以看以下两篇文章。

JS 动画比 CSS3 动画性能谁更好? - 知乎 (zhihu.com)

CSS and JavaScript animation performance - Web 性能 | MDN (mozilla.org)

  1. gpu 为什么更快(瞎扯)

  2. 事件循环说一说

  3. 事件循环题目

    setTimeout(() => {
      new Promise(res => {
        console.log(2);
        res();
      }).then(() => {
        console.log(1);
      });
      console.log(4);
    }, 0);
    setTimeout(() => {
      console.log(3);
    });
    console.log(5);
  4. sum(1)(2)(3),写的不是很好面试官给提示了

function cureer(fn) {
  let params = [];
  return function newFn(...newParams) {    // 这里剩余参数漏了提醒一次
      params = [...params, ...newParams]
    if(params.length === fn.length) {
      return fn(...params);    // 这里扩展运算符漏了没看出来提醒了一次
    } else {
      return newFn
    }
  }
}
function getSum(a, b, c) {
  return [...arguments].reduce((a, b) => a + b, 0);
}
const sum = cureer(getSum);
console.log(sum(1)(2)(3));
  1. 归并排序,合并有序列表写糊涂了,后面重写了

  2. 反问,问了部门做什么的以及学习建议,建议多了解一些前端的新知识提到了一开始说的 vite

面试体验很好,总体来说不难,前端工程化了解的不多答的也不是很细,http 问了好多我也不知道为什么,就把知道的都给说了,也给了提示,面试官好喜欢笑搞得我也忍不住笑。

#美团暑期实习##实习##面经#
全部评论
请问sum(1)(2)(3)是完全自己实现嘛?还是有要求
1 回复 分享
发布于 2022-04-03 19:46
楼主base 哪里呀
1 回复 分享
发布于 2022-04-01 17:20
为啥凉了啊
点赞 回复 分享
发布于 2022-04-21 11:29
为啥凉了啊
点赞 回复 分享
发布于 2022-04-21 11:26
东理小学弟呀
点赞 回复 分享
发布于 2022-04-17 22:28
lz 哪个部门啊
点赞 回复 分享
发布于 2022-04-08 16:00
好详细,谢谢大佬分享
点赞 回复 分享
发布于 2022-04-03 20:50

相关推荐

bg双非本科,方向是嵌入式。这次秋招一共拿到了&nbsp;8&nbsp;个&nbsp;offer,最高年包&nbsp;40w,中间也有一段在海康的实习经历,还有几次国家级竞赛。写这篇不是想证明什么,只是想把自己走过的这条路,尽量讲清楚一点,给同样背景的人一个参考。一、我一开始也很迷茫刚决定走嵌入式的时候,其实并没有一个特别清晰的规划。网上的信息很零散,有人说一定要懂底层,有人说项目更重要,也有人建议直接转方向。很多时候都是在怀疑:1.自己这种背景到底有没有机会2.现在学的东西到底有没有用3.是不是已经开始晚了这些问题,我当时一个都没答案。二、现在回头看,我主要做对了这几件事第一,方向尽早确定,但不把自己锁死。我比较早就确定了嵌入式这个大方向,但具体做哪一块,是在项目、竞赛和实习中慢慢调整的,而不是一开始就给自己下结论。第二,用项目和竞赛去“证明能力”,而不是堆技术名词。我不会刻意追求学得多全面,而是确保自己参与的每个项目,都能讲清楚:我负责了什么、遇到了什么问题、最后是怎么解决的。第三,尽早接触真实的工程环境。在海康实习的那段时间,对我触动挺大的。我开始意识到,企业更看重的是代码结构、逻辑清晰度,以及你能不能把事情说清楚,而不只是会不会某个知识点。第四,把秋招当成一个需要长期迭代的过程。简历不是一次写完的,面试表现也不是一次就到位的。我会在每次面试后复盘哪些问题没答好,再针对性补。三、我踩过的一些坑现在看也挺典型的:1.一开始在底层细节上纠结太久,投入产出比不高2.做过项目,但前期不会总结,导致面试表达吃亏3.早期有点害怕面试,准备不充分就去投这些弯路走过之后,才慢慢找到节奏。四、给和我背景相似的人一点建议如果你也是双非,准备走嵌入式,我觉得有几件事挺重要的:1.不用等“准备得差不多了”再投2.项目一定要能讲清楚,而不是做完就算3.不要只盯着技术,多关注表达和逻辑很多时候,差的不是能力,而是呈现方式。五、写在最后这篇总结不是标准答案,只是我个人的一次复盘。后面我会陆续把自己在嵌入式学习、竞赛、实习和秋招中的一些真实经验拆开来讲,希望能对后来的人有点帮助。如果你正好也在这条路上,希望你能少走一点弯路。
x_y_z1:蹲个后续
点赞 评论 收藏
分享
评论
11
93
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务