虾皮提前批前端一二面 面筋
base深圳 问题顺序不一定对
一面
1.项目:图片滚动懒加载怎么做的,节流防抖
2.隐藏元素的三种方式,区别
3.浏览器渲染页面的过程,display none的元素在不在渲染树
4.外边距折叠是什么,如何解决
5.bfc是什么,如何开启
6.0.1+0.2是不是等于0.3,为什么
7.0.5的二进制如何计算,给定10000.23如何设计字节存储,解释一下符号位,单精度,双精度
8.给你一个大数5000w,如何快速计算它的二进制
9.react的hook,常见hook
10.hook与类组件的区别
11.useeffect的依赖项是否可以是一个方法
12.如何设计一个hook,以保证被它包裹的函数地址不会发生变化(就是ahook的usepersistfn)
13.react性能优化有哪些
14.js如何监听一个元素的变化
15.vue依赖收集原理
16.defineProperty如何监听数组变化(拦截改变数组的7个方法)
16.proxy怎么实现监听,相较于vue2的实现有哪些优点
17.算法大数相加
二面
1.实习做了什么
2.讲一讲实习做的native开发,以及全栈页面开发经验,后端用的什么
3.三道题看代码说输出
var a = 3 var total = 0 var res = [] function foo(a) { var i=0 for (; i < 3; i++) { res[i] = function () { total += a * i console.log(total); } } } foo(1) res[0]()//3 res[1]()//6 res[2]()//9
function test() {} test.prototype.print = function () { console.log('test') } Object.prototype.print = function () { console.log('obj') } let t = new test() t.print()//test test.print()//obj还有一道eventloop的题,记不清了
4.讲一讲eventloop
5.对hook的理解
6.react组件通信的方式
7.react组件触发render的方式
8.react的state前后都是1会触发render吗
9.实现useUpdate
const useUpdate= ()=> { const setState=useState({})[1] return useCallback(()=>{ setState({}) },[]) }10.回流重绘,如何实践
11.浏览器缓存,强缓存,协商缓存
12.百度页面请求谷歌api带不带cookie
13.sameSite属性
14.cookie的domain字段
15.跨域处理,详细说一下nginx反向代理