百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

如何写成高性能的代码(一):巧用Canvas绘制电子表格

zhezhongyun 2025-01-24 14:46 45 浏览

什么是Canvas

Canvas是HTML5的标签,是HTML5的一种新特性,又称画板。顾名思义,我们可以将其理解为一块画布,支持在上面绘制矩形、圆形等图形或logo等。

需要注意的是,与其他标签不同,Canvas只是一块空画布,其本身是不能绘制图形的,必须通过JavaScript 脚本进行绘制。

大多数现代浏览器都支持Canvas技术,例如Chrome、Firefox以及最新的IE9以上版本。

IE8及以下不支持H5,所以也不支持Canvas,不过我们可以在Canvas标签之间书写内容,来提示用户升级或使用支持的浏览器打开。

Canvas与DOM的区别

如果想绘制一个图形,你会有几种思路呢?

在HTML5出现之前,大家通常会使用SVG(本质上也是DOM)绘制,使用XML语言中描述图形的具体信息,进一步渲染图形。

也有同学会直接使用DOM进行绘制,比如借助div标签画个矩形,并结合CSS进行样式的渲染。

对比Canvas和DOM,二者究竟有哪些区别呢?

1、 绘制的图片格式不同

DOM是使用矢量图进行页面渲染的,每一个元素都是一个独立的DOM元素。作为一个独立的DOM元素,CSS和JavaScript都可以直接操纵DOM,对其进行监听。

而canvas本质上是一张位图,其构成最小单位是像素,其中的图形不会单独创建DOM元素。

2、 工作机制不同

前面提到,DOM作为矢量图进行渲染,如果页面内容复杂时,系统就会创建特别多的DOM元素。浏览器在渲染时就需要对所有的DOM元素进行解析计算,庞大的计算量易导致页面卡顿或者渲染过度。

在渲染Canvas时,浏览器的每次重绘都是基于代码的,只需要在内存中构建出画布,在JS引擎中执行绘制逻辑,然后遍历整个画布中像素点的颜色直接输出到屏幕就可以了。

也就是说,不管canvas中的元素有多少个,浏览器在渲染阶段也只需要处理一张画布,而不是像矢量图那样,需要对所有的DOM元素进行计算。这也就是Canvas的最大优势:渲染性能。

除此之外,因为Canvas的绘制是在JS层通过代码控制的,所以在灵活性方面较DOM也有很大的优势。

攻克电子表格技术的性能难点

电子表格发展以来,以其便捷性、即时性深深影响了人们的生活。微软认为世界上每五个成年人中就有一个使用 Excel (源于“微软 Excel 的最新发展” ,2017年9月)。随着互联网技术的发展,电子表格结合在线系统也成为大多企业呈现分析数据的优选方案,发挥出巨大的作用。

在实际的业务场景中,Web表格不仅只是展示数据,伴随来的还有复杂精美的样式、繁琐灵活的操作,来帮助开发者更快捷地获取整合数据。

结合前文分析的Canvas和DOM工作机制,如果数据量不大,浏览器绘制电子表格时二者性能差异不会很明显。

但如果在工业制造、金融财会等行业中,所使用电子表格动辄就是上百万行,浏览器不仅需要对单元格内容进行渲染,还需要涉及到丰富的数据处理,这对前端性能就会有很大的挑战。

传统的DOM进行渲染时,如果执行更新、滚动等操作,就需要不停地销毁创建DOM,这无形中也增加了大量无效计算,容易造成页面卡顿等渲染问题。

而使用canvas绘制,就不会有重复创建、销毁DOM操作,打破了DOM元素对UI的诸多限制,同时也可以绘制种类更为丰富的UI元素,如线性、特殊图形等。

好消息是,目前业内已经出现了使用Canvas技术绘制画布的前端表格控件-SpreadJS。

不仅如此,SpreadJS在使用canvas绘制的过程中,还引入了双缓存画布的机制,将不易改变的主题图层绘制在缓存画布中,在发生渲染行为时,只需要将缓存画布中的主体图层通过克隆的方式绘制在主画布,并附加装饰图层元素,这种“双剑合璧“的形式大大优化了电子表格的绘制性能。

相关推荐

3 分钟!AI 从零开发五子棋全过程曝光,网友:这效率我服了

<!DOCTYPEhtml><htmllang="zh-CN"><head><metacharset="UTF-8...

一行代码实现display&quot;过渡动画&quot;原理

作者:Peter谭老师转发链接:https://mp.weixin.qq.com/s/XhwPOv62gypzq5MhhP-5vg写本文的起因上篇文章,提到如何让display出现过渡动画,却没有仔...

脑洞:琼恩·雪诺、蝙蝠侠和魔形女的灵魂宠物了解一下

AlekseiVinogradovisaRussianfreelancedigitalartistwhoshareshisskillsandtalentwith120k...

浏览器的渲染机制、重绘、重排

1、什么是重排和重绘网页生成过程:HTML被HTML解析器解析成DOM树css则被css解析器解析成CSSOM树结合DOM树和CSSOM树,生成一棵渲染树(RenderTree)生成布局(flo...

托福写作高频考题写作思路&amp;词汇丨考虫独家

科技话题与媒体话题是托福写作的常考话题很多考生对这两类话题里的专有词汇表达也许很不了解所以今天就跟随考虫托福写作老师刘云龙老师一起来学习在这些话题的写作里你可以使用哪些有用的表达。希望大家有收获!记得...

在优麒麟上使用 Electron 开发桌面应用

使用Web标准来创建桌面GUI,上手快、成本低、跨平台、自适应分辨率,这些都是Electron的优势。作者/来源:优麒麟Electron是由Github开发,用HTML、CSS和...

php手把手教你做网站(三十八)jquery 转轮盘抽奖,开盲盒

抽奖和开盲盒性质一样的都是通过ajax读取后台的随机数据。1、转轮盘本来是想直接绘图实现轮盘,但是没有找到怎么填充文字,只好把轮盘弄成了背景图,通常用于游戏抽道具,商城积分抽奖,公司年末员工抽奖点击抽...

用 CSS 整活!3D 轮播图手把手教学,快乐代码敲出来

兄弟们,今天咱来搞点好玩的——用CSS整一个3D轮播图!咱野生程序员就是要在代码里找乐子,技术和快乐咱都得要!代码是写不完的,但咱能自己敲出快乐来,走起!一、先整个容器,搭个舞台咋先写一个...

实现一个超酷的 3D 立体卡片效 #前端开发

今天我们来实现一个超酷的3D立体卡片效果。正常情况下就是一个普通的图片展示卡片,鼠标悬停的时候图片会跳出卡片,并将影子投射到背景卡片上,在视觉上有一个3D立体感。html主要分成3个部分:容器→背景层...

Vue 3 Teleport与Suspense:解决UI难题的两个&quot;隐藏大招&quot;

模态框的"层级噩梦"与Teleport的救赎"这个模态框怎么又被父容器截断了?"团队协作开发后台系统时,小张第N次遇到这个问题。多层嵌套的组件结构里,弹窗被overfl...

让交互更加生动!有意思的鼠标跟随 3D 旋转动效

今天,群友问了这样一个问题,如下所示的鼠标跟随交互效果,如何实现:简单分析一下,这个交互效果主要有两个核心:借助了CSS3D的能力元素的旋转需要和鼠标的移动相结合本文,就将讲述如何使用纯CSS...

填坑:transform元素导致zindex失效终极方法

今天遇到了使用css3动画的元素层级被放大置顶的问题,ios浏览器上没问题,安卓原生浏览器和安卓微信上有问题。使用了css3动画的元素z-index失效,兄弟元素设置多高的z-index都盖不住解决办...

诡异的层级错乱:一个被transform隐藏的CSS陷阱

周五下午三点十七分,设计部突然发来紧急截图——原本应该悬浮在顶部的导航菜单,此刻正诡异地被下方的轮播图遮挡。我盯着屏幕上错乱的层级关系,手指下意识地敲下z-index:9999,心里清楚这不过是程序...

动画篇--碎片动画

本文授权转载,作者:Sindri的小巢(简书)前言从最开始动笔动画篇的博客,至今已经过去了四个多月。这段时间回头看了看自己之前的动画文章,发现用来讲解动画的例子确实不那么的赏心悦目。于是这段时间总是想...

Nature:大洋转换断层处的拉张构造与两阶段地壳增生

Nature:大洋转换断层处的拉张构造与两阶段地壳增生转换断层是三种基本的板块边界之一,全球总长度超过48000km(Bird,2003),它们的发现为板块构造理论的建立奠定了重要的基础(Wil...