蓝蓝设计分享--提高JS性能的12个技巧 - 昌平网站建设推广 - 北京小生活网
北京 [切换城市]

北京站

蓝蓝设计分享--提高JS性能的12个技巧

更新时间:2023/11/9 9:22:32信息编号:2056-553604
所属分类:
商务服务 网站建设推广 
所在区域:
北京 昌平
详细地址:
昌平区天通苑中苑61号楼4单元1502室
联 系 人:
蓝蓝
电  话:
18801051825
收录查询: 百度 搜狗 360   分享更易传播
小生活网提醒您:1、在办理服务前请确认对方资质, 夸大的宣传和承诺不要轻信!2.任何要求预付定金、汇款至个人银行账户等方式均存在风险,谨防上当受骗!
详细介绍


在我们开发的过程中,应该始终考虑性能xbaixing.com。而本文列举了有效提高系统性能的12个方法,如果朋友们有更多的技巧请在吴小迪的博客下方评论,谢谢。
 性能是创建网页或应用程序时最重要的一个方面。没有人想要应用程序崩溃或者网页无法加载,或者用户的等待时间很长。根据Kissmetrics,47%的访问者希望网站在不到2秒的时间内加载,如果加载过程需要3秒以上,则在40%的访问者会离开网站。
考虑到以上这些数字,你在创建Web应用程序时应始终考虑性能。为了帮助你开始,以下提供了有效提高应用程序性能的12种方法:
一:在浏览器中缓存
要这样做有俩种选择。第一种是使用JavaScript Cache API,我们可以安装service worker来使用它。第二种是使用HTTP协议缓存。
访问某个对象通常要用脚本。通过把重复访问的对象存储在用户定义的变量中,以及在后续对该对象的引用中使用变量,可以立即实现性能的提升。
二:定义执行的上下文
为了有效地衡量你在程序中加入的任何改进,你必须创建一组定义良好的环境,以便测试代码性能。

对所有JavaScript引擎的所有版本进行性能测试和优化实际上是不可行的。但是,在单一的环境中进行测试并非一个好习惯,因为你可能会得到片面的结果www.xbaixing.com小百姓网。因此,建立多个定义良好的环境并测试代码是否有效非常重要。
三:删除未使用的JavaScript
此步骤不仅会缩短传输时间,还会缩短浏览器分析和编译代码所需的时间。为此,你必须考虑以下几点:
如果你检测到一个用户未使用的功能,最好删除所有与之相关的JavaScript代码,这样网站的加载速度会更快,用户也有更好的体验。
还有可能,你错误地加入了一个并不需要的库,或者你有依赖项,这些依赖项提供的功能在所有浏览器中原本就有,那么你无需再增加多余的代码。
四:避免使用太多内存
你应该始终给内存加一条限制,那就是只有绝对必须的内容才能使用内存,因为你无法知道运行应用程序的设备到底需要多少内存。只要你的代码要求浏览器保留新的内存,浏览器的垃圾收集器就会被执行,并停止JavaScript的运行。如果经常发生这种情况,页面将变慢。
五:推迟不必要的JS加载
用户希望页面快速加载,但并非所有函数都需要在页面的初始加载时就可用。如果用户必须执行某个操作才能执行某个函数(例如,通过单击某个元素或更改选项卡),那么你可以将该函数的加载推迟到初始页面加载之后。
通过这种方式,你可以避免加载和编译那些会延迟页面初始显示的 JavaScript 代码。页面完全加载后,我们可以再开始加载这些功能,以便它们在用户开始交互时立即可用。在 RAIL 模型中,Google 建议将此延迟加载以 50 毫秒为单位进行,这样就不会影响用户与页面的交互。
六:避免内存泄漏
如果内存正在泄漏,则加载的页面将保留越来越多的内存,并最终占用设备的所有可用内存并严重影响性能小+百+姓+网。你可能见过此类故障(并且可能对此类故障感到懊恼),例如在带有轮播或图像滑动条的页面上。
Chrome 开发者工具中,你可以通过在“性能”标签中记录时间线来分析你的网站是否存在内存泄漏。通常,内存泄漏的原因是,你从页面中删除了 DOM,但有一些变量还在引用这些 DOM,因此,垃圾收集器无法消除它们。
七:适当的使用Web worker
当你执行耗时很长的代码时,请使用 Web worker。根据 Mozilla 开发人员网络 (MDN) 文档:“Web Worker 可以在与 Web 应用程序的主执行线程分开的后台线程中运行脚本操作。这样做的好处是你可以在一个单独的线程中执行耗时又费力的的处理,同时让主(通常为 UI)线程运行而不被阻塞或减慢。”

Web worker 允许代码执行处理器密集型计算,而不阻塞用户界面线程。Web Worker 允许你生成新线程并将工作委托给这些线程以获得高效的性能。这样,通常会阻碍其他任务且需要长时间运行的任务将被传递给 worker,从而让主线程可以在无阻碍的情况下运行。
八:适当将DOM元素保存在局部变量中
访问 DOM 会很慢。如果要多次读取某元素的内容,最好将其保存在局部变量中。但记住重要的是,如果稍后你会删除 DOM 的值,则应将变量设置为“null”,不然会导致内存泄漏。
九:优先访问局部变量
JavaScript 首先搜索以查看变量是否存在于本地,然后才在更高级别的作用域内逐步搜索到全局变量为止x b a i x i n g c o m。将变量保存在本地作用域内能让 JavaScript 更快地访问它们。
局部变量是基于最具体的作用域的,并且可能会穿过多个级别的作用域,因此查找这一动作可能导致出现通用的查询。在一个它前面没有变量声明的局部变量中定义函数作用域时,需要在每个变量之前加上 let 或 const,以便定义当前作用域,防止查找并加速代码执行。
十:避免使用全局变量
因为脚本引擎在从函数或其他作用域内引用全局变量时需要逐一查看作用域,所以当本地作用域丢失时,该变量将被销毁。如果全局作用域中的变量无法在脚本的生命周期内持续存在,则性能将得到改善。
十一:实施一些优化方案
始终使用计算复杂度最低的算法和最佳的数据结构来解决任务。
重写算法以获得相同的结果和更少的计算。
避免递归调用。
给重复的函数加入变量、计算和调用。
分解和简化数学公式。
使用搜索数组:用它们来获取基于另一个的值,而不是使用 switch/case 语句。
使条件总是更有可能为真,以更好地利用处理器的推测执行。
如果可以,请使用位级运算符替换某些操作,因为这些运算符的处理周期较短www.xbaixing.com

十二:使用工具检测问题
Lighthouse 是一个很好的网页性能工具,它可以帮助你审核性能、可访问性、最佳实践和 SEO。谷歌 PageSpeed 旨在帮助开发人员了解网站的性能优化和潜在可改进的方面。这些组件旨在识别网站是否符合 Google Web 性能最佳实践,以及将调整过程自动化。
Chrome 中,你还可以使用主菜单中的“更多工具”选项来查看每个选项卡使用的内存和 CPU。对于更高级的分析,你可以使用 Firefox 或 Chrome 中的开发人员工具“性能”视图来分析不同的指标,例如:
devtools 的性能分析允许你在加载页面时模拟 CPU 消耗、网络和其他指标,以便识别和修复问题。
为了更深入地了解,建议你使用 JavaScript Navigation Timing API,它允许你详细测量代码的每个部分从编程本身中获取的内容。
对于基于 Node.js 构建的应用程序,NodeSource Platform 也是一种非常好、影响低的方式,它可以在非常精细的级别上探索应用程序性能。
全面的 Node.js 指标可帮助你识别内存泄漏源或其他性能问题,并更快地解决这些问题。
最后的说明在代码的可读性和优化之间保持平衡很重要。代码由计算机解释,但我们需要确保代码将来可以由我们自己或其他人维护,因此它们需要易于理解。更多文章就在蓝蓝设计每日一贴。蓝蓝设计为企业提供卓越的大屏设计、UI界面设计BS界面设计、cs界面设计、用户体验、交互设计、网站建设、包装设计计、图标定制、平面设计服务。
您可以直接联系优秀的软件ui设计提供者北京蓝蓝设计

欢迎访问,开始愉快的合作!


温馨提示:蓝蓝设计分享--提高JS性能的12个技巧”由用户自行发布,信息内容的真实性、准确性和合法性由发布人负责。虽然部分网友认证了账号,但是并不代表没有风险。小生活网不提供任何保证不参与交易,亦不承担任何法律责任。
北京网站建设推广全部地区
海淀网站建设推广朝阳网站建设推广东城网站建设推广西城网站建设推广崇文网站建设推广宣武网站建设推广丰台网站建设推广石景山网站建设推广昌平网站建设推广通州网站建设推广大兴网站建设推广顺义网站建设推广房山网站建设推广密云网站建设推广门头沟网站建设推广怀柔网站建设推广平谷网站建设推广延庆网站建设推广燕郊网站建设推广北京周边网站建设推广
北京网站建设推广热门城市
北京网站建设推广上海网站建设推广深圳网站建设推广广州网站建设推广成都网站建设推广天津网站建设推广苏州网站建设推广杭州网站建设推广武汉网站建设推广郑州网站建设推广南京网站建设推广济南网站建设推广青岛网站建设推广重庆网站建设推广西安网站建设推广宁波网站建设推广石家庄网站建设推广沈阳网站建设推广厦门网站建设推广长沙网站建设推广
北京网站建设推广周边服务
北京签证北京咨询北京快递北京法律咨询北京贷款担保北京办公设备维修北京会计审计北京设计策划北京建材北京翻译服务北京喷绘招牌北京保险北京租赁北京产品供应加工北京印刷包装北京投资理财北京工商注册北京代理记账北京注册公司北京礼品北京网络维护/布线北京其他商务服务北京网站建设推广北京商标专利北京展览展会北京起名风水北京物流北京抵押贷款北京小额贷款北京网上贷款北京信用贷款北京无抵押贷款
全国网站建设推广最新信息
宝鸡app软件开发 小程序软件开发APP小程序开发H5游戏网站开发微商城专业配眼镜近视眼镜常熟市专业通下水道马桶网络新闻发布、主流新闻媒体发稿、河南电视台网络新闻报道山东华为零售网络解决方案山东华为交换机产品报价网页设计,网站建设,微信小程序开发,APP商城设计开发,到泰安深度科技承接各类软件开发定制广告联盟APP撸包小游戏定制开发