当前位置: 首页 > 面试经验 >

12.14 蓝湖前端一面

优质
小牛编辑
122浏览
2023-03-28

12.14 蓝湖前端一面

时长:90min

面试官问得很灵活,是根据学了什么来问的,收获很大。

  • 自我介绍
  • 虚拟列表实现(答得不好)
  • 聊到了执行环境(聊了蛮久)
  • 手写执行环境伪码
  • 面试官说写一个闭包结合写的伪码来讲述执行环境原理
  • 聊到了继承
  • 有几种继承,它们的缺点是什么(没答得太好,用call继承的方案叫啥名儿忘记了,我说用call继承会让重复逻辑的函数重复创建,造成资源浪费,面试官说 错,然后进行了解释)PS:感觉我这么答也ok哇。
  • 之后给面试官说手写组合寄生继承被拒绝,说后面再写,其实能不能写出来心里也没底...
  • 原型式继承和原型链继承的区别
  • 我说会有一个原型键能否溯源的区别
  • 一个是直接new 一个是使用Object.create来在原型上去写
  • 手写obj.create()
  • 手写New
  • 类相关问题
  • 算法,图(没A出来),补充runAllTask函数,同时支持异步。
  • 解释:遍历input,比如遇到第一项,id为task1,deps依赖为空,第一项调用runTask就直接返回3;第二项deps依赖id为task1和task3的runTask返回值,因此res1为task1的返回值,res2为task2的返回值,但是此时task3还没有执行,因此本轮循环无法获取值;遍历到第三项时,依赖task1,可以获取到值,runTask返回8;

interface Task {
id: string;
deps: string[];
runTask: Function;
}

const input = [
{
id: "task1",
deps: [],
runTask: () => 3,
},
{
id: "task2",
deps: ["task1", "task3"],
runTask: (res1, res3) => 1 + res1 + res3,
},
{
id: "task3",
deps: ["task1"],
runTask: (res1) => 5 + res1,
},
{
id: "task4",
deps: ["task1", "task2"],
runTask: (res1, res2) => 3 + res1 + res2,
},
];

function runAllTask(list: Task[],cb:any) {
// ...
}

runAllTask(input, (err, res) => {
console.log(res);
/**
res应该为:
{ task1: 3, task2: 12, task3: 8, task4: 18 }
*/
});
  • 反问问面评
    答:还可以,但是作为应届的同学算法有点薄弱(24届的同学算应届的同学吗,问号脸),会有2面。
  • 问团队做什么的,websocket使用多吗。
    答:做B端的,不多。

倒了,无二面,但是收获很多,后面会去重新巩固基础。

#蓝湖##前端面经##面经##前端##面试复盘#
 类似资料: