浏览器性能优化

IIFE惰性函数

有一些函数在运行时需要进行一些判断,但是这个判断只需要执行一次,代码一旦运行判断结果就不会改变,这样的函数称为惰性函数,可以使用下面的手段来进行优化

javascript 复制代码
// 优化前,每次调用都需要进行一次判断
function doThing() {
	if(globalThis === 'window') {
		// do something in browser
	} else if(globalThis === 'global') {
		// do something in nodejs
	}
}

// 这样优化过后doThing就是一个已经进行过判断的函数,不必每次执行时都判断
doThing = (() => {
	if(globalThis === 'window') {
		return function() {
			// do something in browser
		}
	} else if(globalThis === 'global') {
		return function() {
			// do something in nodejs
		}
	}
})()

冻结对象

在Vue中有一些数据仅仅只做展示而不回去修改它,这些数据我们就可以冻结起来,被冻结的对象讲无法进行任何修改

javascript 复制代码
// 加入我们拿到了一个10万条数据的数据,这样做会导致10w条数据全部被创建为响应式对象,十分消耗性能
this.list = getList();

// 如果只是展示数据,那么可是将对象冻结,Vue做了相关的优化,不会将被冻结的对象创建为响应式
// 被冻结的对象会变为只读属性,无法进行任何修改
this.list = Object.freeze(getList());

// 通过Object.isFrozen() 可以判断一个对象是否被冻结
let flag = Object.isForzen(this.list);
相关推荐
放下华子我只抽RuiKe542 分钟前
FastAPI 全栈后端(三):数据库与 ORM
前端·数据库·react.js·oracle·性能优化·前端框架·fastapi
源图客1 小时前
境外电商 - 龙虾智能体-综合选品推荐报告
开发语言·javascript·ecmascript
磊 子1 小时前
C++设计模式
javascript·c++·设计模式
梵得儿SHI1 小时前
Vue 项目实战与性能优化全攻略:从代码、渲染到首屏,一站式解决卡顿慢加载
前端·vue.js·性能优化·vite·前端面试·前端优化·首屏优化
ShyanZh1 小时前
【skill】HTML PPT Skill:用 Claude Code 一句话生成专业演示文稿
前端·ai·html·powerpoint·skill
AI视觉网奇1 小时前
three教学 3d资产拼接源代码
前端·css·css3
程序猿阿伟2 小时前
《Chrome标签组搭建多任务高效浏览指南》
前端·chrome
2601_958352902 小时前
双麦 DSP 音频模块实战:一文梳理 A-68 在全行业场景的声学解决方案与落地要点
前端·嵌入式硬件·音视频·语音识别·降噪消回音·音频处理模块
智码看视界3 小时前
老梁聊全栈:JavaScript 原型链深入探索对象继承的奥秘
前端·javascript·ecmascript
智码看视界3 小时前
老梁聊全栈系列 JavaScript语言本质:从原型链到异步编程的深度解析
开发语言·javascript·全栈·javascript核心