JavaScript经典面试题的专业回答(一),带你全面理解View的绘制流程

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
img

正文

面试官:那究竟是什么原因导致没有释放呢?

  • 根据JS的垃圾回收机制,当内存中引用的次数为0的时候内存才会被回收

  • 全局执行上下文中的对象被标记为不再使用才会被释放

2.内存泄露的几种场景
  • 全局变量过多通常是变量未被定义或者胡乱引用了全局变量

// main.js

// 场景1

function a(){

b=10;

}

a();

b++;

// 场景2

setTimeout(()=>{

console.log(b)

},1000)

  • 闭包。 未手动解决必包遗留的内存引用。 定义了闭包就要消除闭包带来的副作用。

function closuer (){

const b = 0;

return ©=> b + c

}

const render = closuer();

render();

render = null; // 手动设置为null,GC会自己去清除

  • 事件监听未被移除

function addEvent (){

const node = document.getElementById(‘warp’);

node.addEventListener(‘touchmove’,()=>{

console.log(‘In Move’);

})

}

const onTouchEnd = (){

const node = document.getElementById(‘warp’);

node.

}

useEffect(()=>()=>{

const node = document.getElementById(‘warp’);

node.removeEventListener(‘touchmove’);

}) // 类似react 生命周期函数: componentWillUnmount

render(

// code…

)
  • 缓存。 不管是啥缓存,都需要设置好过期时间。

面试官: 那你能不能说说你是如何排查内存泄露的?

分析一波:到这,回答中规中矩。但面试官的问题真的就到这了吗? 明显不是。 面试官问你是如何排查问题,其实就是再问,你是如何定位到问题的。

也就是说,内存泄露会导致页面卡顿,甚至是页面崩溃。相信你在用APP得开发包或者开发包测试问题的时候,肯定遇到过整个APP闪退的事情,因为在真机器调试的过程中难免会遇见内存不够用的时候。

那么,问题来了。 内存泄露会导致页面卡顿或者崩溃,那页面卡顿就是内存泄露导致的吗? 所以面试官真正想问的是,你是如何发现某个页面有可能发生了内存泄露,并且你是如何诊断该问题是内存泄漏引起的。

我在其它文章里有提过,前端性能优化首先得确立一些性能指标,那内存泄漏不正式性能指标的一种吗?那明确了指标不就是该去获取相关数据,然后上报给性能平台吗?

3.内存泄漏相关性能指标的确立
  • window 对象上新增加的属性数量

  • 在加载页面之前Object.kyes(window)

  • 离开页面(路由跳转、页面关闭、后台APP关闭等)之前 Object.kyes(window)

  • 一些特殊函数,例如产生闭包的函数变量是否重新赋值为null. 也就是说你写的闭包有被清理掉吗?或者说,

function closuer(){

const a = 0;

return (b)=> a + b

}

API.addClosuer(closuer);

const result = closuer();

API.addClosuer(result);

result = null;

closuer = null;

// 记录页面离开的时间,和被监听的闭包函数有没有被释放。

const list = API.getClosuer(); // 被监听的闭包函数集合,最好的结果就是 {closuer:null,result: null,…}

API.上报(API.getClosuer());

这样,你的性能平台上就能看见这一次上报的数据,页面里什么时候产生了闭包,又是什么时候闭包被清除了,也就一清二楚。

  • 事件触发的次数以及事件处理的时间。

  • 如果js主线程堵塞了,那当下场景的事件触发也就一定会延迟或者无限等待。 这里用 performance.now

  • performance.now()方法返回当前网页从performance.timing.navigationStart到当前时间之间的微秒数,其精度可达100万分之一秒

  • performance.now() 近似等于 Date.now(),但前者返回的是毫秒,后者返回的是微秒,后者的精度比前者高1000倍。

  • 页面DOM元素数量是否异常。

  • 深度优先遍历,获取DOM树的深度。这里可以根据不同场景不同页面来设定DOM树深度的最大阀值。超过最大阀值则平台进行预警。 因为这意味着页面有动态新增DOM的事情发生。

  • FPS,有明显长波段的不平稳。

  • 重绘的次数。

最后

为了让大家快速精通JavaScript,在这里免费分享给大家一份Javascript学习指南。

Javascript学习指南文档涵盖了javascript 语言核心、词法结构 、类型、值和变量 、表达式和运算符 、语句、对象 、数组 、函数 、类和模块 、 正则表达式的模式匹配、 javascript的子集和扩展 、服务器端javascript /客户端javascript 、web浏览器中的javascript 、window对象 、脚本化文档、脚本化css 、事件处理等22章知识点。内容丰富又详细,拿下互联网一线公司offfer的小伙伴都在看。

每个知识点都有左侧导航书签页,看的时候十分方便,由于内容较多,下面列举的部分内容和图片。

对象

  • 创建对象

  • 属性的查询和设置

  • 删除属性

  • 检测属性

  • 枚举属性

  • 属性getter和setter

  • 属性的特性

文末

我一直觉得技术面试不是考试,考前背背题,发给你一张考卷,答完交卷等通知。

首先,技术面试是一个 认识自己 的过程,知道自己和外面世界的差距。

更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。

前端面试题汇总

JavaScript

性能

linux

前端资料汇总

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

ttps://img-blog.csdnimg.cn/img_convert/6e0ba223f65e063db5b1b4b6aa26129a.png)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-SjtkNcFI-1713686084716)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 26
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值