【JavaScript】3.2 JavaScript性能优化
文章目录
- 1. 避免全局查找
- 2. 避免不必要的属性查找
- 3. 使用快速的JavaScript方法
- 4. 避免不必要的DOM操作
- 5. 使用Web Workers进行后台处理
- 总结
性能优化是任何编程语言的重要组成部分,JavaScript也不例外。在这个章节中,我们将探讨如何优化JavaScript代码,以提高网页的性能和响应速度。我们会讨论一些常见的性能问题,以及如何解决它们。
1. 避免全局查找
在JavaScript中,全局变量是存储在全局对象上的。在浏览器中,全局对象就是window
对象。每次访问一个全局变量,JavaScript引擎都需要在全局对象上进行查找。这个查找过程可能会比在局部作用域中查找变量要慢。
例如,考虑以下的代码:
for (var i = 0; i < window.array.length; i++) {// do something with window.array[i]
}
在这个例子中,每次循环时,JavaScript引擎都需要在全局对象上查找array
。这会使得代码运行得更慢。
一个更好的做法是将全局变量存储在一个局部变量中,然后在循环中使用这个局部变量。
var array = window.array;
for (var i = 0; i < array.length; i++) {// do something with array[i]
}
在这个例子中,JavaScript引擎只需要在循环开始时查找一次array
。这会使得代码运行得更快。
2. 避免不必要的属性查找
在JavaScript中,访问对象的属性需要进行属性查找。属性查找的速度取决于属性在原型链中的位置。如果一个属性在原型链的末尾,那么查找这个属性的速度就会比较慢。
例如,考虑以下的代码:
for (var i = 0; i < obj.subObj.array.length; i++) {// do something with obj.subObj.array[i]
}
在这个例子中,每次循环时,JavaScript引擎都需要在obj.subObj.array
上查找length
。这会使得代码运行得更慢。
一个更好的做法是将属性的值存储在一个局部变量中,然后在循环中使用这个局部变量。
var array = obj.subObj.array;
for (var i = 0; i < array.length; i++) {// do something with array[i]
}
在这个例子中,JavaScript引擎只需要在循环开始时查找一次length
。这会使得代码运行得更快。
3. 使用快速的JavaScript方法
JavaScript提供了许多方法来处理数组和对象。然而,并非所有的方法都是等价的。有些方法比其他方法更快。
例如,考虑以下的代码:
var array = [1, 2, 3, 4, 5];
var newArray = [];
for (var i = 0; i < array.length; i++) {newArray.push(array[i] * 2);
}
在这个例子中,我们使用了一个循环和push
方法来创建一个新的数组。这个过程可能会比较慢。
一个更好的做法是使用map
方法。
var array = [1, 2, 3, 4, 5];
var newArray = array.map(function(x) { return x * 2; });
在这个例子中,map
方法会更快地创建一个新的数组。
4. 避免不必要的DOM操作
在JavaScript中,DOM操作是非常耗时的。每次修改DOM,浏览器都需要重新计算页面的布局,并重新绘制页面。因此,我们应该尽量减少DOM操作。
例如,考虑以下的代码:
var list = document.getElementById('list');
for (var i = 0; i < 1000; i++) {var item = document.createElement('li');item.textContent = 'Item ' + i;list.appendChild(item);
}
在这个例子中,我们在循环中添加了1000个列表项。每次添加一个列表项,浏览器都需要重新计算页面的布局,并重新绘制页面。这会使得代码运行得非常慢。
一个更好的做法是使用文档片段(DocumentFragment
)。
var list = document.getElementById('list');
var fragment = document.createDocumentFragment();
for (var i = 0; i < 1000; i++) {var item = document.createElement('li');item.textContent = 'Item ' + i;fragment.appendChild(item);
}
list.appendChild(fragment);
在这个例子中,我们在循环中添加了1000个列表项到文档片段中,然后一次性添加文档片段到列表中。这样,浏览器只需要重新计算页面的布局并重新绘制页面一次。这会使得代码运行得更快。
5. 使用Web Workers进行后台处理
JavaScript是单线程的,这意味着所有的操作都在同一个线程中顺序执行。如果有一个操作需要很长时间才能完成,那么其他的操作就需要等待这个操作完成才能开始。
例如,考虑以下的代码:
function longRunningTask() {// do something that takes a long time
}longRunningTask();
updateUI(); // this has to wait for longRunningTask to finish
在这个例子中,updateUI
函数需要等待longRunningTask
函数完成才能开始。这可能会导致用户界面冻结,给用户带来不好的体验。
一个更好的做法是使用Web Workers。Web Workers允许我们在后台线程中运行JavaScript代码,这样就不会阻塞主线程。
var worker = new Worker('worker.js');
worker.postMessage({ command: 'start' });
updateUI(); // this can run immediately
在这个例子中,我们创建了一个新的Web Worker,并发送了一个消息给它。Web Worker会在后台线程中处理这个消息。这样,updateUI
函数就可以立即运行,不需要等待longRunningTask
函数完成。
总结
性能优化是一个复杂的主题,需要考虑许多因素。在这个章节中,我们只是简单地介绍了一些基本的优化技巧。在实际开发中,我们还需要使用性能分析工具,如Chrome的DevTools,来分析我们的代码,找出性能瓶颈,然后进行优化。只有这样,我们才能编写出高性能的JavaScript代码。
相关文章:
【JavaScript】3.2 JavaScript性能优化
文章目录 1. 避免全局查找2. 避免不必要的属性查找3. 使用快速的JavaScript方法4. 避免不必要的DOM操作5. 使用Web Workers进行后台处理总结 性能优化是任何编程语言的重要组成部分,JavaScript也不例外。在这个章节中,我们将探讨如何优化JavaScript代码&…...
pytorch bert实现文本分类
以imdb公开数据集为例,bert模型可以在huggingface上自行挑选 1.导入必要的库 import os import torch from torch.utils.data import DataLoader, TensorDataset, random_split from transformers import BertTokenizer, BertModel, BertConfig from torch import…...
《开箱元宇宙》:Madballs 解锁炫酷新境界,人物化身系列大卖
你是否曾想过,元宇宙是如何融入世界上最具代表性的品牌和名人的战略中的?在本期的《开箱元宇宙》 系列中,我们与 Madballs 的战略顾问 Derek Roberto 一起聊聊 Madballs 如何在 90 分钟内售罄 2,000 个人物化身系列,以及是什么原…...
4K-Resolution Photo Exposure Correction at 125 FPS with ~8K Parameters
MSLTNet开源 | 4K分辨率125FPS8K的参数量,怎养才可以拒绝这样的模型呢? 错误的曝光照片的校正已经被广泛使用深度卷积神经网络或Transformer进行广泛修正。尽管这些方法具有令人鼓舞的表现,但它们通常在高分辨率照片上具有大量的参数数量和沉…...
网络初识:局域网广域网网络通信基础
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、局域网LAN是什么?二、广域网是什么:三. IP地址四.端口号五.认识协议5.1五元组 总结 前言 一、局域网LAN是什么? 局域网…...
JVM之jps虚拟机进程状态工具
jps虚拟机进程状态工具 1、jps jps:(JVM Process Status Tool),虚拟机进程状态工具,可以列出正在运行的虚拟机进程,并显示虚拟机执 行主类(Main Class,main()函数所在的类)的名称,…...
C++实现顺序栈的基本操作(扩展)
#include <stdio.h> typedef char ElemType; #define StackSize 100 /*顺序栈的初始分配空间*/ typedef struct { ElemType data[StackSize]; /*保存栈中元素*/int top; /*栈顶指针*/ } SqStack; void InitStack(SqStack &st) {st.top-1; } …...
用python写一个简单的爬虫
爬虫是一种自动化程序,用于从互联网上获取数据。它能够模拟人类浏览网页的行为,访问网页并提取所需的信息。爬虫在很多领域都有广泛的应用,例如数据采集、信息监控、搜索引擎索引等。 下面是一个使用Python编写的简单爬虫示例: …...
分布式追踪
目录 文章目录 目录自定义指标1.删除标签2.添加指标3.禁用指标 分布式追踪上下文传递Jaeger 关于我最后最后 自定义指标 除了 Istio 自带的指标外,我们还可以自定义指标,要自定指标需要用到 Istio 提供的 Telemetry API,该 API 能够灵活地配…...
make -c VS make -f
make 是一个用于构建(编译)项目的工具,它通过读取一个名为 Makefile 的文件来执行构建任务。make 命令有很多选项和参数,其中包括 -c 和 -f。 make -c: 作用:指定进入指定的目录并执行相应的 Makefile。 示…...
Unity 代码控制Color无变化
Unity中,我们给Color的赋值比较常用的方法是: 1、使用预定义颜色常量: Color color Color.white; //白色 Color color Color.black; //黑色 Color color Color.red; //红色 Color color Color.green; //绿色 Color color Color.blue; …...
【Erlang进阶学习】2、匿名函数
受到其它一些函数式编程开发语言的影响,在Erlang语言中,将函数作为一个对象,赋予其“变量”的属性,即为我们的匿名函数 或 简称 fun,它具有以下特性: (匿名函数:不是定义在Erlang模…...
肖sir__mysql之视图__009
mysql之视图 一、什么是视图 视图是一个虚拟表(逻辑表),它不在数据库中以存储形式保存(本身包含数据),是在使用视图的时候动态生成。 二、视图作用 1、查询数据库中的非常复的数据 例如:多表&a…...
FPGA falsh相关知识总结
1.存储容量是128M/8 Mb16MB 2.有256个sector扇区*每个扇区64KB16MB 3.一页256Byte 4.页编程地址0256 5:在调试SPI时序的时候一定注意,miso和mosi两个管脚只要没发送数据就一定要悬空(处于高组态),不然指令会通过两…...
升辉清洁IPO:广东清洁服务“一哥”还需要讲好全国化的故事
近日,广东物业清洁服务“一哥”升辉清洁第四次冲击IPO成功,拟于12月5日在香港主板挂牌上市。自2021年4月第一次递交招股书,时隔两年半,升辉清洁终于拿到了上市的门票。 天眼查显示,升辉清洁成立于2000年,主…...
Python自动化办公:PDF文件的分割与合并
我们平时办公中,可能需要对pdf进行合并或者分割,但奈何没有可以白嫖的工具,此时python就是一个万能工具库。 其中PyPDF2是一个用于处理PDF文件的Python库,它提供了分割和合并PDF文件的功能。 在本篇博客中,我们将详细…...
破解app思路
1.会看smali代码逻辑 一.快速定位关键代码 1.分析流程 搜索特征字符串 搜索关键 api 通过方法名来判断方法的功能 2.快速定位关键代码 反编译 APK 程序 AndroidManifest.xml>包名/系统版本/组件 程序的主 activity(程序入口界面) 每个 Android 程序…...
36.位运算符
一.什么是位运算符 按照二进制位来进行运算的运算符叫做位运算符,所以要先将操作数转换成二进制(补码)的形式在运算。C语言的中的位运算符有: 运算符作用举例结果& 按位与(and) 0&00; 0&10; …...
C#异常处理-throw语句
throw语句是我们手动引发异常的一个语句。 在程序执行过程中,当某些条件不符合我们的要求时,那么我们就可以使用throw语句手动抛出异常,那么就可以在异常发生的地方终止当前代码块的执行,此时我们就可以把控制权传递给调用堆栈中…...
PlantUML语法(全)及使用教程-时序图
目录 1. 参与者1.1、参与者说明1.2、背景色1.3、参与者顺序 2. 消息和箭头2.1、 文本对其方式2.2、响应信息显示在箭头下面2.3、箭头设置2.4、修改箭头颜色2.5、对消息排序 3. 页面标题、眉角、页脚4. 分割页面5. 生命线6. 填充区设置7. 注释8. 移除脚注9. 组合信息9.1、alt/el…...
231204 刷题日报
21. 合并两个有序链表 单调栈没看懂,晚上回家再说吧 380. O(1) 时间插入、删除和获取随机元素 今天被接雨水钉在耻辱柱,找时间再看吧...
PTA 7-229 sdut-C语言实验- 排序
给你N(N<100)个数,请你按照从小到大的顺序输出。 输入格式: 输入数据第一行是一个正整数N,第二行有N个整数。 输出格式: 输出一行,从小到大输出这N个数,中间用空格隔开。 输入样例: 5 1 4 3 2 5输出样例: 1 2 3 4 5 #include <stdio.h>…...
原生横向滚动条 吸附 页面底部
效果图 /** 横向滚动条 吸附 页面底部 */ export class StickyHorizontalScrollBar {constructor(options {}) {const { el, style } optionsthis.createScrollbar(style)this.insertScrollbar(el)this.setScrollbarSize()this.onEvent()}/** 创建滚轴组件元素 */createS…...
1+x网络系统建设与运维(中级)-练习3
一.设备命名 AR1 [Huawei]sysn AR1 [AR1] 同理可得,所有设备的命名如上图所示 二.VLAN LSW1 [LSW1]vlan 10 [LSW1-vlan10]q [LSW1]int g0/0/1 [LSW1-GigabitEthernet0/0/1]port link-type access [LSW1-GigabitEthernet0/0/1]port default vlan 10 [LSW1-GigabitEt…...
知识图谱07——图片中表格开源ocr识别
对比了多种ocr识别算法,最终选择了百度paddle官方的ocr算法 在所在的虚拟环境下运行 pip install paddleocr --userfrom paddleocr import PaddleOCR import os import csv# 创建 PaddleOCR 对象 ocr PaddleOCR(use_gpuTrue) # 无gpu时选择False# 指定图片文件夹…...
每日一练2023.12.4——正整数【PTA】
一时间网上一片求救声,急问这个怎么破。其实这段代码很简单,index数组就是arr数组的下标,index[0]2 对应 arr[2]1,index[1]0 对应 arr[0]8,index[2]3 对应 arr[3]0,以此类推…… 很容易得到电话号码是18013…...
golang之net/http模块学习
文章目录 开启服务开启访问静态文件获取现在时间按时间创建一个空的json文件按时间创建一个固定值的json文件 跨域请求处理输出是json 开启服务 package mainimport ("fmt""net/http" )//路由 func handler(w http.ResponseWriter, r *http.Request){fmt.…...
Python中format函数用法
嗨喽~大家好呀,这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 format优点 format是python2.6新增的一个格式化字符串的方法,相对于老版的%格式方法,它有很多优点。 1.不需要理会数据类型的问题&#…...
Android 断点调试
Android 调试 https://developer.android.google.cn/studio/debug?hlzh-cn 调试自己写的代码(不在Android源码) 点击 Attach debugger to Android process 图标 需要在添加断点界面手动输入函数名 但也可以不手动,有个技巧可以new 空proje…...
sae wordpress 上传图片/百度网站登录
4.3.3 route 命令 路由表管理命令 路由表主要构成: Destination: 目标网络ID,表示可以到达的目标网络ID,0.0.0.0/0 表示所有未知网络,又称为默认路由,优先级最低Genmask:目标网络对应的netmaskIface: 到达对应网络,应该从当前主机哪个网卡发送出来Gateway: 到达非直连的网络,…...
广州优化网站建设/免费推广网站注册入口
在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG. 其中,对于我们日常的分析有用的就是前面的五个字段。 它们的含义是: SYN表示建立连接, FIN表示关闭连接, ACK表示…...
网站建立网络优化/天津百度快照优化公司
Java语言的特点 特点一:面向对象 两个基本概念:类、对象。三大特性:封装、继承、多态。 特点二:健壮性 吸收了C/C语言的优点,但去掉了其影响程序健壮性的部分(如指针、内存的申请与释放等)&…...
郑州网站建设公司 艾特/移动建站模板
办公室是企业办公的地方,对于企业而言,一个办公室的形象对于企业在团队精神、宣传展示时十分关键,对于整体实力协作、客户信赖的展示也是有一定的影响。人们在对办公空间合理、利润较大化利用的同时,如何打造一个时尚的办公空间设…...
wordpress完整安装包/网址安全检测中心
目录 JQuery初级 概念快速入门JQuery对象和JS原生对象的区别选择器DOM操作 内容操作属性操作CRUD操作 案例 JQuery高级 动画遍历事件绑定插件 Ajax 概念实现方式 原生JS实现(了解)JQuery实现方式 $.ajax()$.get()$.post() json 概念语法 基本规则获取数据遍历 …...
网站建设续费是什么费用/轻松seo优化排名
今天上午的蓝桥杯比赛让我正视了很多以前没有注意的问题,也找到了很多自以为会了,其实是盲点的知识点。 10个题都不难,放到平时,如果是在oj上,肯定能全部AC,可是比赛的时候,写的并不好。 尤其…...