2021年度总结 | 葡萄城软件开发技术回顾(上) (2)

Blazor是基于.NET平台及ASP.NET Core技术构建交互式客户端Web UI的框架。开发者可以使用 C# 而不是 JavaScript 构建交互式 Web UI。如此可以方便开发者使用C#编写客户端和服务器代码。

为了更加方便进行报表查看,现在推出了新的报表查看器组件——Blazor Viewer。它为应用程序提供了报表渲染,展示,交互,打印导出的全功能,方便我们更加高效的地构建 Web应用。

主要功能包括:

用.NET代码在服务器端渲染用户界面

在服务器端用.NET代码处理用户交互

为开发人员提供C# API,用于打开报表、处理事件和定制报表展示界面

同时随着2021年.Net 6的升级和VS2022的推出,也一并升级兼容。

2021年度总结 | 葡萄城软件开发技术回顾(上)

JavaScript 平台

在过去的版本中,ARJS采用的npm包使用的是CommonJS,AMD等模块规范。但是这些规范在使用过程中,会出现一些问题。如CommonsJS比较适合服务端,在服务器读取模块都是在本地磁盘,加载速度很快;但是如果在客户端,加载模块的时候有可能出现"假死"状况。

为了解决这个问题,我们将报表控件的npm包全包采用ES6本身支持的模块化语法。

npm 包公开了原生 ES 模块,利用 ES 模块可以为我们应用程序的开发和构建提供卓越的性能。

现在只要浏览器支持ES6的模块化,项目工程就不用再费时间和精力去进行编译和打包,项目工程体积更小,编译的性能会更快。

同时框架支持更为丰富, Vite.js,Vue 3, Angular 13等前端框架现在都完全支持。

除了以上两点,为了保证报表性能适应更大体量的数据报表生成,我们一直致力于优化报表引擎以提升报表性能,基于平台和开发语言的限制,精细化的优化各个报表生成的关键节点,此次采用变量式数据结构存储,使得整个报表的性能提升非常显著。

对于性能提升,很难将JavaScript中的 "1+1"运算优化,但可以优化内存分配,并将比较操作的数量减少到2个,因此我们采用形如以下的变量存储方法:

{ Type: \'float\' | \'string\' | \'boolean\' | \'int16\' | \'int32\' … Value: object }

变量用于结果展示时候,在进行数据引擎交互计算,因此执行如"1+1"表达式时只需要执行三次内存分配和4次转换,而不计算条件运算符的数量如switch和if,从而减少时间和内存的消耗。

在实际测试中,我们也发现这种方法可以有效提升报表性能,真正实现了增量式大数据量缓存加载机制。

同时,为了进一步突破报表功能限制,为报表控件实现了静默打印。有兴趣同学可以查看之前的文章:https://www.cnblogs.com/powertoolsteam/p/15502771.html

2021年度总结 | 葡萄城软件开发技术回顾(上)

复杂报标报表固然复杂,但我们依旧在不断努力,让复杂报标报表不再那么复杂,成为人人手中皆可用好的实用开发工具。

总结

技术的发展与融合比我们想象的更为迅速,在元宇宙、AI、前端、云、数据、运维等无数关键词的裹挟下,计算机网络技术正在不断生长和演进。

而我们也从未停下前进的脚步,从前端电子表格技术、BI数据分析,到复杂报表的处理解决与风头正盛的低代码,立足当下,展望未来。

本次我们从葡萄城历史最悠久的控件出发,为大家介绍了今年的技术亮点与突破,在下篇内容中,我们将继续带大家回顾葡萄城过去一年在新兴领域中,有哪些可圈可点的技术升级。

2021年度总结 | 葡萄城软件开发技术回顾(上)

2021年度总结 | 葡萄城软件开发技术回顾(上)

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zggdzy.html