前端面试题及答案汇总

 

github地址

前端面试题及答案汇总

第 1 期:写 React / Vue 项目时为什么要在组件中写 key,其作用是什么

解析:第一题:key的作用是为了在diff算法执行时更快的找到对应的节点,提高diff速度。

第 2 期:['1', '2', '3'].map(parseInt) what & why ?

解析:第二题:[‘1’, ‘2’, ‘3’].map(parseInt) 解析

第 3 期:什么是防抖和节流?有什么区别?如何实现?

解析:第三题:节流和防抖的个人见解

第 4 期:介绍下 Set、Map、WeakSet 和 WeakMap 的区别?

解析:第四题:Set、Map、WeakSet 和 WeakMap

第 5 期:介绍下深度优先遍历和广度优先遍历,如何实现?

解析:关于第五题我的一些见解

第 6 期:请分别用深度优先思想和广度优先思想实现一个拷贝函数?

解析:第六题 实现深度拷贝

第 7 期:ES5/ES6 的继承除了写法以外还有什么区别?

解析:第 7 期:ES5/ES6 的继承除了写法以外还有什么区别?解答与一个疑惑

第 8 期:setTimeout、Promise、Async/Await 的区别

欢迎在 Issue 区留下你的答案。

第 9 期:Async/Await 如何通过同步的方式实现异步

欢迎在 Issue 区留下你的答案。

第10期:异步笔试题

请写出下面代码的运行结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
async function async1() {
console.log('async1 start');
await async2();
console.log('async1 end');
}
async function async2() {
console.log('async2');
}
console.log('script start');
setTimeout(function() {
console.log('setTimeout');
}, 0)
async1();
new Promise(function(resolve) {
console.log('promise1');
resolve();
}).then(function() {
console.log('promise2');
});
console.log('script end');

解析:关于第10题的一些见解

第11题:算法手写题

已知如下数组:

var arr = [ [1, 2, 2], [3, 4, 5, 5], [6, 7, 8, 9, [11, 12, [12, 13, [14] ] ] ], 10];

编写一个程序将数组扁平化去并除其中重复部分数据,最终得到一个升序且不重复的数组

解析:第11题:将数组扁平化并去除其中重复数据,最终得到一个升序且不重复的数组

第12题:JS 异步解决方案的发展历程以及优缺点。

解析:第十二题

第13题:Promise 构造函数是同步执行还是异步执行,那么 then 方法呢?

解析:关于第13题的见解

第14题:情人节福利题,如何实现一个 new

解析:14题 情人节快乐!

第15题:简单讲解一下http2的多路复用

解析:第15题:简单讲解一下http2的多路复用

第16题:谈谈你对TCP三次握手和四次挥手的理解

解析:关于第16题的见解

第17题:A、B 机器正常连接后,B 机器突然重启,问 A 此时处于 TCP 什么状态

如果A 与 B 建立了正常连接后,从未相互发过数据,这个时候 B 突然机器重启,问 A 此时处于 TCP 什么状态?如何消除服务器程序中的这个状态?(超纲题,了解即可)

解析:关于17题的见解

第18题:React 中 setState 什么时候是同步的,什么时候是异步的?

解析:第18题:React 中 setState 什么时候是同步的,什么时候是异步的?

第19题:React setState 笔试题,下面的代码输出什么?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class Example extends React.Component {
constructor() {
super();
this.state = {
val: 0
};
}

componentDidMount() {
this.setState({val: this.state.val + 1});
console.log(this.state.val); // 第 1 次 log

this.setState({val: this.state.val + 1});
console.log(this.state.val); // 第 2 次 log

setTimeout(() => {
this.setState({val: this.state.val + 1});
console.log(this.state.val); // 第 3 次 log

this.setState({val: this.state.val + 1});
console.log(this.state.val); // 第 4 次 log
}, 0);
}

render() {
return null;
}
};

解析:关于第19题的见解

本文作者: blog.zerbo.cn
本文链接: https://blog.zerbo.cn/post/10282.html
版权声明: 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。转载请注明出处!