热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

从JS引擎角度剖析DataFlux前端性能,多维度提升网站用户体验

从,js,引擎,角度,剖析,dataflux,前端,性能,多维,度,提升

性能与体验一直都是前端开发中老生常谈的话题,也是开发出一款优秀web应用必须要考虑的问题。随着google V8引擎的发布,Node的诞生,前端能做的事情也越来越多,浏览器的能力也被无限放大和利用。如何在能够在完成迭代需求的基础上,逐步优化网站性能以及体验,充分利用浏览器的能力突破性能瓶颈,提升交互体验,趋优网站亲和性,则成为了一个前端开发必须逾越的鸿沟。
01_jpeg

这篇文章我们结合DataFlux前端应用,从浏览器和Javascript引擎角度来剖析前端性能,指出DataFlux前端应用在性能优化这块的优缺点。

在文章开始前,先大体聊聊 DataFlux 这款产品为什么要注重性能以及交互体验。DataFlux是一个实时大数据分析平台。看名称我们可以扣到两个字眼,“实时”、“分析”,小编认为“实时”应该对应及时、准确,而“分析”则应该对应直观、参考、预测、趋势。所以极致优化网站目前性能,提升交互体验更是成为了重中之重。

其实性能与交互问题可以简单一句话描述“能够在最短的时间内,让用户看到自己想看到的东西”。而能够由前端去实现的无非就是降低交互延迟,减少页面卡顿,美化页面效果。

首先我们谈谈怎么以前端的角度去降低交互延迟。

降低交互延迟我们可以从两个方面去考虑,网络请求、代码逻辑,网络请求可以细分成文件请求以及 AJax异步请求。

我们可以用chrome打开Dataflux SaaS应用网站,然后打开开发者工具,如下图:02_jpeg

影响网络请求延迟的原因可能是当前网络环境因素、服务器数据返回的延迟、包内容过大等等因素造成,一般对于服务器数据返回所造成的延迟,前端开发很难对其进行优化,当然对于一些不常变更,及时性要求不是那么高的数据,我们可以在前端做一个本地缓存处理,下次加载可以先加载本地缓存,然后再异步请求去更新数据。

如果是因为数据包过大也让引起的延迟,我们可以采用分步加载数据包,优先加载用户关注高的数据的方式去降低延迟。

对比dataflux下图我们可以看出一些东西:同样大小的数据包,「query_data」这个接口用了156ms的响应时间而另外一个接口只用了73ms,也就排除了是由当前网络环境的影响,可以确定是服务端在处理数据能力上的延迟。并且我们可以看出「query_data」是还是一个调用比较频繁的请求,这里面对交互体验的影响还是蛮大的。

所以这里我的建议是后端同学可以优化优化代码
03_jpeg

从JS引擎角度剖析DataFlux前端性能,多维度提升网站用户体验

静态文件请求的优化点

聊完了ajax异步请求,我们聊聊静态文件请求的优化点,静态文件影响的延迟包括几个方面:体积过大,数量过多,脚本同步执行阻塞渲染。

对于体积过大的问题,我们可以用各种工具对文件压缩,分模块加载,设置响应缓存以及浏览器缓存的方式减缓延迟,这里面我着重提一下http缓存以及浏览器缓存,因为其他因素都可以由各种前端框架的cli去配置实现,着实没啥可说。http 缓存是 web 性能优化中非常重要的一种手段,把一些常用资源在首次加载时缓存到浏览器本地,再次加载时可大大减少请求次数,缓存的资源越多,性能当然越好。

PS:缓存的规则主要有两种,强制缓存和对比协商缓存,两种缓存分别通过Http报文头部不同的字段进行控制。

因为脚本的同步执行造成的阻塞渲染,我们都知道浏览器解析渲染 DOM Tree 和 CSS Tree,解析执行 Javascript,几乎所有的操作都是在主线程中执行。因为 Javascript 可以操作 DOM,影响渲染,所以 Javascript 引擎线程和 UI 线程是互斥的。换句话说,Javascript 代码执行时会阻塞页面的渲染。

解决这个问题无非是让脚本加载执行的时候,不影响到渲染。所以我们可以把样式文件放到head头部,而脚本文件放到body尾部。或者在script标签上加defer属性,来表明脚本在执行的时候,不会影响页面的结构。也就是说,脚本会被延迟到整个页面都解析完毕后再运行。但采用这种方法,会有一种缺陷。在有些浏览器中。并不会按照你自己文件的顺序执行下来。并且有的浏览器还会忽略这种属性。还有一种方式就是利用html5中一个很有用但是经常被忽略的特性,就是预加载(perfetch),他的原理是:利用浏览器的空闲时间去先下载用户指定需要的内容,然后缓存起来,这样用户下次加载时,就直接从缓存中取出来,效率就加快了。当然这些新的特性,对浏览器的版本要求还是比较高的,如果对兼容性要求比较高的话,还是老老实实用尾部大法吧。

回到我们的应用,看下图:从图中我们可以看出,在静态文件缓存利用上我们做的还是比较好的
04_jpeg
05_jpeg

也用到了上面说到的prefetch特性。当然这也得益于vue-cli 的强大。。不足之处就是由的文件体积过大,会导致首次加载时间过长,执行效率降低。这里我的建议是,能够剔除文件之中不需要的模块,减少重复代码来减小文件体积。

代码逻辑方面的优化

至于代码逻辑方面的优化,我们可以从页面渲染以及执行效率两方面着手。

影响页面渲染的因素有很多,总结下来也是一句话,dom元素不要过多,不要频繁触发”重排(reflow)”,同时尽量减少因为Javascript 引擎线程和 UI 线程的互斥性阻塞页面的渲染的影响。

dom元素不要过多:

调整页面布局结构,去除不必要的dom节点

频繁触发”重排(reflow)”:

需要注意的是,"重绘"不一定需要"重排",比如改变某个网页元素的颜色,就只会触发"重绘",不会触发"重排",因为布局没有改变。但是,"重排"必然导致"重绘",比如改变一个网页元素的位置,就会同时触发"重排"和"重绘",因为布局改变了。所以我们可以从在脚本中减少例如增加、修改、删除 DOM元素或者对 DOM集合的操作。在css文件中对于一下会触发重排的元素放到class的开头,触发repaint的元素放到后面, 在遍历选择某个元素样式时不要嵌套太深..等的方式减少reflow次数。
06_jpeg

我看可以看dataflux应用的部分截图:

可以看出平台是非常依赖浏览器的GPU渲染能力,因为我们主要的方向都是在数据展示分析上,所以上面一些问题是目前我们必须要面对的问题,上图中,因为一个节点要展示的图表有可能十个,几十个甚至还可能出现地图类型的图表。在这些图表我们使用的svg元素,毕竟在处理大型渲染区域的环境上,svg优于canvas,但是这也衍生出一个问题,页面的html元素会越来越多,导致页面结构越来越复杂,解析速度会越来越慢。所以在这个问题上我们的解决方案是,优先展示用户关注的图表,只渲染屏幕区域内的元素,屏幕区域外的元素直接删除,数据缓存等方式去优化页面卡顿,反应迟缓等问题。当然除了上面说的,在代码风格上,因为我们用的是vue,所以也尽量遵循vue官方的风格指南以及cookbook。

以前端开发的方式去优化整个网站的用户体验

最后聊聊如何以前端开发的方式去优化整个网站的用户体验

其实我们比其他人的优势是更懂得如何去设计网页和增加网站实用性。举几个例子:

  1. 使用“for”属性允许用户点击标签,就可以选择到表单中整个的输入区域,这对单选框和复选框扩大点击区域十分重要。但要注意选择内容的匹配
  2. 在链接上应该给用户一个视觉上的提示,告诉他/她网页中的哪些链接是已访问过的。
  3. 使用输入框或输入域时,选择使用“focus”或其它方式,展示出哪一个区域在当前是处于激活状态的,这一点对用户很有帮助
  4. 图片标签应该加上alt图片描述,另外当你的图片存在链接时,图片描述应该包括链接地址
    ….

篇幅有限,欢迎大家使用 Dataflux.cn~

当然上面都是小编的一些个人经验总结,如有不妥之处还请多多包涵
_2020_05_13_4_26_41


推荐阅读
  • 使用HTML和JavaScript实现视频截图功能
    本文介绍了如何利用HTML和JavaScript实现从远程MP4、本地摄像头及本地上传的MP4文件中截取视频帧,并展示了具体的实现步骤和示例代码。 ... [详细]
  • 本文深入解析了JDK 8中HashMap的源代码,重点探讨了put方法的工作机制及其内部参数的设定原理。HashMap允许键和值为null,但键为null的情况只能出现一次,因为null键在内部通过索引0进行存储。文章详细分析了capacity(容量)、size(大小)、loadFactor(加载因子)以及红黑树转换阈值的设定原则,帮助读者更好地理解HashMap的高效实现和性能优化策略。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 本文将介绍如何在混合开发(Hybrid)应用中实现Native与HTML5的交互,包括基本概念、学习目标以及具体的实现步骤。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 在《Cocos2d-x学习笔记:基础概念解析与内存管理机制深入探讨》中,详细介绍了Cocos2d-x的基础概念,并深入分析了其内存管理机制。特别是针对Boost库引入的智能指针管理方法进行了详细的讲解,例如在处理鱼的运动过程中,可以通过编写自定义函数来动态计算角度变化,利用CallFunc回调机制实现高效的游戏逻辑控制。此外,文章还探讨了如何通过智能指针优化资源管理和避免内存泄漏,为开发者提供了实用的编程技巧和最佳实践。 ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • 为了确保iOS应用能够安全地访问网站数据,本文介绍了如何在Nginx服务器上轻松配置CertBot以实现SSL证书的自动化管理。通过这一过程,可以确保应用始终使用HTTPS协议,从而提升数据传输的安全性和可靠性。文章详细阐述了配置步骤和常见问题的解决方法,帮助读者快速上手并成功部署SSL证书。 ... [详细]
  • 如何利用BAT脚本在Windows 10中实现一键清理系统垃圾文件?
    在Windows 10中,如何通过BAT脚本实现一键清理系统垃圾文件?许多用户在使用电脑时,往往忽略了定期清理缓存和临时文件的重要性,这会导致系统性能逐渐下降。通过编写和运行BAT脚本,用户可以轻松实现自动化清理,提高系统效率。 ... [详细]
  • POJ 2482 星空中的星星:利用线段树与扫描线算法解决
    在《POJ 2482 星空中的星星》问题中,通过运用线段树和扫描线算法,可以高效地解决星星在窗口内的计数问题。该方法不仅能够快速处理大规模数据,还能确保时间复杂度的最优性,适用于各种复杂的星空模拟场景。 ... [详细]
  • Android中将独立SO库封装进JAR包并实现SO库的加载与调用
    在Android开发中,将独立的SO库封装进JAR包并实现其加载与调用是一个常见的需求。本文详细介绍了如何将SO库嵌入到JAR包中,并确保在外部应用调用该JAR包时能够正确加载和使用这些SO库。通过这种方式,开发者可以更方便地管理和分发包含原生代码的库文件,提高开发效率和代码复用性。文章还探讨了常见的问题及其解决方案,帮助开发者避免在实际应用中遇到的坑。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 优化后的标题:利用 jQuery 实现高效树形结构元素选择与操作
    在Web前端开发中,DOM结构本质上是一种树形结构。通过优化后的jQuery选择器,可以高效地选择和操作DOM树中的节点。这些选择器不仅简化了代码编写,还提高了性能和可维护性。本文将详细介绍如何利用jQuery的树形选择器实现高效的元素选择与操作。 ... [详细]
author-avatar
终渐疯分_501
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有