JavaScript性能优化方案,你知道几个?

js性能优化建议

修剪HTML

JavaScript HTML很复杂,在查询时间、查询和修改DOM对象方面起着至关重要的作用。

当你把应用程序的HTML切成两半时,DOM的速度可能会翻倍。 这可能很困难,但是通过丢弃像

和 这样的标签是可能的。

批处理DOM更改

批处理DOM转换,以防止重复出现屏幕渲染。 当创建样式更改时,一次完成所有的更改,而不是对每个样式单独应用更改。

学习异步编程的方法

JavaScript应用程序需要对大量api进行多次内部调用来获取数据。

每个函数都需要中间件,因为JavaScript是单线程的。

同步组件有时会锁定整个应用程序。 JavaScript使用async.js管理异步代码。

异步代码不会阻塞线程。 相反,威胁将被硬塞到事件队列中,该事件队列在执行其他代码之后触发。

使用JavaScript异步特性,可能会无意中利用外部库来恢复异步干扰调用。

这会降低JavaScript的性能。 相反,应该在代码中使用异步api,尤其是在关键的性能部分。

使用gzip压缩

JavaScript文件可能非常庞大。 利用GZip来解压和压缩文件。 GZip减少延迟时间,提高应用程序性能,并节省带宽。 使用GZip,服务器在将资源发送到浏览器之前对其进行压缩。

利用HTTP / 2

HTTP的最新版本是HTTP/2,它提高了JavaScript的性能,加快了网站的性能。

HTTP/2利用多路复用,允许同时发送多个响应和请求。

缓冲DOM

如果有可滚动的div,可以使用一个缓冲区来清除当前在视口中不可见的DOM项。 这些技术节省了DOM遍历和内存使用。

限制库依赖关系

加载时间会影响库的依赖关系,所以将利用率保持在最低水平是很重要的。

利用外部库依赖的最好方法是依赖于浏览器内技术。

当使用CSS选择器时,使用Sizzle.js而不是jQuery。 当库包含单个特性时,单独添加CSS选择器是至关重要的。

保持代码轻巧

保持JavaScript代码紧凑将减少延迟并提高性能。 当优化JavaScript性能时,问问自己:

  • 这个模块有真正的需求吗?

  • 使用这个框架的原因是什么?

  • 开销值吗?

  • 有更简单的方法吗?

通过将多个JS文件转换为一个来优化JavaScript性能。

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

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

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
取!!**](https://bbs.csdn.net/topics/618191877)

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 11
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值