4、架构:Canvas VS DOM

可视化搭建的低代码平台中,设计器是一个非常关键的模块,可以帮助用户通过拖拽、配置等方式快速搭建应用界面

在技术选型方面,目前市面上主流的设计器技术包括基于 HTML/CSS/JavaScript 的 Web 设计器。

在渲染方案方面,主流的设计器通常采用基于虚拟 DOM 的渲染方案,比如 ReactVue 等,这种渲染方案可以提高渲染性能和开发效率,同时也支持组件化开发,使得设计器更加易于维护和扩展。

除了渲染方案,设计器的交互体验也非常重要,为了提高用户体验,主流的设计器通常会提供丰富的交互组件和动画效果,比如拖拽、缩放、动态添加组件等功能,以及实时预览、撤销重做等操作,这些功能会非常考验渲染方案的选择以及研发的设计与开发功底。

所以要设计一个易于使用、高效的低代码平台设计器,我们需要综合考虑技术选型渲染方案交互体验等多个方面的因素,本章将会针对设计器中可视化搭建的方案做一些技术上的选型探讨以及介绍一下市面上一些主流设计器的渲染方案。

浏览器渲染的方式


在开始进行渲染方式的选择之前,我们先来了解下在浏览器中渲染视图的常见方案:

  • HTML DOM:目前大多数都是使用其来绘制大部分的前端需求,使用起来非常的灵活和便捷,提供了配套全面的事件处理机制来处理相关的交互操作。主打的优势就是其便携性,学习成本低,上手简单容易。不过在内存开销、渲染速度等方面并不是很占优势,是其的薄弱环节;
  • Canvas(画布)HTML5 中,提供了 Canvas 画布元素,通过 <canvas/> 和绘制 API 在web页面上呈现图形、动画和图像。与 DOM 不同,Canvas 主打的优势在于灵活性高、性能出色、跨平台渲染等特点。但 Canvas 的上手成本很高,需要了解 JavaScript Canvas 相关画布 api,不支持 SEO 等等缺陷。设立的门槛让很多想尝试的前端同学望而却步;
  • WebGLWebGL 是比较新颖成熟的 3D 渲染引擎,主要用于在 Web 浏览器中呈现复杂的 3D 图像和动画。可以实现高性能的 3D 图形渲染和复杂场景绘制。同时支持硬件加速,调用 GPU 资源来渲染图形,极大的提高了渲染速度。基于 WebGL 的 Three.js 深受广大开发者的青睐。不过相应的缺点就是对基础设备有一定的要求,对低端设备不太友好。另外上手困难,不仅仅需要具备前端开发知识,同时也需要了解图形学、数学相关的一些理念和知识;
  • SVG:虽然 SVG 也能够在浏览器上绘制内容,但是与上面的几种技术相比,就明显薄弱很多了,不管是从性能上,还是易用程度而言都没有突出的亮点。不过 SVG 在浏览器图形高保真上有自己独有的优势,因此很多时候都会使用 SVG 的图标来保证相关设计的还原度,拥有更好的呈现效果的同时,也拥有比同位图文件更小的体积。

以上是在浏览器渲染视图的各种方案介绍,可以很明显的看出,DOM 与 Canvas 两种方案综合来看优势会比较明显,所以大部分的低代码产品会选择 DOM 和 Canvas 两者其中一个做为渲染器,不排除某些另辟蹊径的特殊项目有其他的选择。

其他平台的策略


上述提到了 DOM 和 Canvas 是比较好的选择,那么不妨先来看看目前市面上比较热门的一些编辑器它们内部究竟是怎么做抉择的呢?

下面只是做一些技术方案的横向对比,不一定是低代码平台,也包含了目前一些比较受欢迎的企业级 D2C 产品。

平台DOMCanvas是否开源
Retool☑️ 🙅
bubble☑️ 🙅
蓝湖 ☑️🙅
即时设计 ☑️🙅
figma ☑️🙅
lowcode-engine(宜搭)☑️ ☑️
amis☑️ ☑️

可以看出上述的 LowCode & D2C 产品,不管是商业化还是开源项目,可视化搭建类型的低代码产品多数都是使用 DOM 方案,而 D2C 类型的产品则是使用 Canvas 会多一些。

Canvas Vs DOM


那么为什么 D2C 产品会倾向选择 Canvas,而低代码平台则是更偏向 DOM 方案呢?

接下来会从一些常见的编辑器的侧重点来一一进行分析。

渲染性能

首先从性能入手,为了让同学更好的来了解。

在浏览器窗口内分别使用 Canvas 和 DOM 的绘制方式来插入 1000 个红色方块,最后使用计时代码记录当前的渲染时间。

可以看到 Canvas 的渲染速度比 DOM 是成倍提升的。

format,png

下面是两者比对的代码:

<div id="BoxContainer" ></div>
<script>
  const container = document.getElementById("BoxContainer");

  const startTime = performance.now();

  for(let i = 0; i < 1000; i++) {
    const square = document.createElement("div");
    square.style.width = "10px";
    square.style.height = "10px";
    square.style.background = "red";
    square.style.position = "absolute";
    square.style.left = Math.random() * 500 + "px";
    square.style.top = Math.random() * 500 + "px";
    container.appendChild(square);
  }

  const endTime = performance.now();
  const renderTime = endTime - startTime;
  console.log(`DOM render time: ${renderTime} ms`);
</script>

<canvas height="500px" width="500px" id="MyCanvas" ></canvas>
<script>
    const canvas = document.getElementById("MyCanvas");
    const ctx = canvas.getContext("2d");

    const startTime = performance.now();

    for(let i = 0; i < 1000; i++) {
        ctx.fillStyle = "red";
        ctx.fillRect(Math.random() * 500, Math.random() * 500, 10, 10);
    }

    const endTime = performance.now();
    const renderTime = endTime - startTime;
    console.log(`Canvas render time: ${renderTime} ms`);
</script>

从渲染的性能上来比,Canvas 无疑是碾压 DOM 的。

事件交互

浏览器 DOM 的优势在于每一个节点都是独立开的,并且具有一套完整易用的浏览器事件系统提供给开发者进行调用,而 Canvas 则是在一个画布平面当中,只能通过元素的 xy 的距离边界来确定交互的元素,然后通过事件的广播进行操作。

首先:看下 DOM 的事件绑定:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <script>
      function handleCanvasClick(event) {
        console.log('鼠标点击了canvas');
      };
    </script>
  </head>
  <body>

    <div onclick="handleCanvasClick()" >click</div>

  </body>
</html>

然后:下面是 Canvas 的事件绑定:

<canvas id="myCanvas" width="400" height="400"></canvas>

<script>
    // 获取canvas元素
    var canvas = document.getElementById("myCanvas");

    // 获取画布上下文
    var ctx = canvas.getContext("2d");

    // 绘制一个圆形
    ctx.beginPath();
    ctx.arc(200, 200, 50, 0, 2 * Math.PI);
    ctx.fillStyle = "red";
    ctx.fill();

    // 添加点击事件监听器
    canvas.addEventListener("click", function(event) {
            // 获取点击位置的坐标
            var x = event.clientX - canvas.offsetLeft;
            var y = event.clientY - canvas.offsetTop;

            // 判断是否点击了圆形
            var distance = Math.sqrt(Math.pow(x-200, 2) + Math.pow(y-200, 2));
            if (distance <= 50) {
                    // 在圆形上方显示鼠标指针的坐标
                    ctx.fillStyle = "black";
                    ctx.font = "20px Arial";
                    ctx.fillText("Clicked at (" + x + ", " + y + ")", x, y - 10);
            }
    });
</script>

上述示例中,分别用 DOM 和 Canvas 实现了一个点击元素的事件。可以看到,两者的实现难度还是存在很大差异的,DOM 直接使用 onclick 来支持相关的事件绑定,而 Canvas 则是在事件内部通过 event 提供的 xy 坐标确定点击的内容归属。

选择

通过上述一些简单的示例,可以有一个比较明确的结论,Canvas 渲染器在图形渲染方面性能确实是非常好的,但从开发体验上来看 DOM 会更加简单,不管是添加内容还是事件系统都比 Canvas 方便,学习成本以及上手成本都会低于 Canvas 方案。

蓝湖即时设计等 D2C 平台绝大部分都是使用 Canvas 作为渲染引擎,其原因是随着设计师上传的素材切图越来越多,如果使用 DOM 来渲染的话,由于节点过多带来的图形渲染的瓶颈会造成使用体验的卡顿,且交互事件并不算太复杂,因此使用 Canvas 能够得到非常好的正向收益。

反观可视化的低代码平台则因为产物是实际应用的原因,不管是现如今 SPA 单页应用还是以前的 HTML 站点都是使用 DOM 来作为页面绘制的主要手段,且页面内容增长远远达不到 D2C 的节点规模的,所以渲染压力相对较小,同时又带有很强的交互逻辑性,物料组件也需要管理和开发,基于以上种种条件下,DOM 自然而然的成为了首选的渲染器绘制方式。

最后就是 Canvas 通常不利于搜索引擎优化(SEO),因为它的内容不易于解析和理解。同时也不支持选择、复制和粘贴等基本的用户界面功能,而 DOM 确很好的支持了这些点。

因此在编辑器渲染技术选型中,需要根据具体的应用场景和需求来选择使用哪种技术:

  • 需要高性能的图形和动画效果,不需要 SEO,可以选择 Canvas;
  • 需要更好的可维护性和易用性,可以选择 DOM

总结


在本章节,主要带大家了解 DOM 和 Canvas 在 D2C 和 Lowcode 领域中的一些应用和技术选型的一些细节点。为后续开发物料组件和渲染引擎模块做一些技术积累,为后续开发做一些知识储备。

但由于大部分的公司的组件化基本都是基于 ReactVue 来开发,在接入低代码平台中的物料中心的时候,采用 DOM 的方案可以节约大量的改造成本,使用过渡也会更为平滑。

所以最终我们可视化搭建的设计器也将选择 DOM 作为搭建技术方案,至于在设计器中存在大量组件渲染卡顿的情况,在本章开头也提到了,除了基础的原生技术方案有区别之外,还可以通过一些额外的研发设计方案来规避,例如数据组装与视图渲染分离等来解决性能问题,这些具体的优化措施我们将放在搭建实战篇进行更多的细节讲解。

参考

  • The Future Web: Will Canvas Rendering Replace the DOM?
  • www.youtube.com/watch?v=Swp…
  • Google Docs is switching to canvas-based rendering. Here's what that means.

写在最后

如果你有什么疑问或者更好的建议,欢迎在评论区提出。 👏

4 架构:Canvas VS DOM

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/34362.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

王道《计算机网络》思维导图汇总

第一章 1.1.1 概念与功能 1.1.2 组成与分类 1.1.3 标准化工作及相关组织 1.1.4 性能指标 速率 带宽 吞吐量 时延 时延带宽积 往返时延RTT 利用率 1.2.1 分层结构、协议、接口、服务 1.2.2 OSI参考模型 应用层 表示层 会话层 传输层 网络层 数据链路层 物理层 1.2.4 TCP/IP 参…

Linux下的分布式迁移工具dsync使用

一、Linux下的分布式迁移工具dsync使用 dsync 是一个在 Linux 系统上用于迁移文件和目录的工具。它可以在不同的存储设备之间进行数据同步和迁移操作。dsync 是 rsync 工具的一个衍生版本&#xff0c;专注于在本地文件系统之间进行数据迁移。 这里是官网&#xff1a;dsync 1、…

游泳买耳机买什么的比较好,列举几款实战性好的游泳耳机

对于运动用户来说&#xff0c;在运动时都会选择听一些节奏感比较强的音乐&#xff0c;让自己运动是更有活力。现在已经是三伏天中的前伏期间&#xff0c;不少人会选择在三伏天的日子里进行减肥瘦身&#xff0c;耳游泳已经成为很多人都首选运动&#xff0c;游泳是非常好的有氧运…

吐血整理!可免费使用的国产良心软件分享,几乎满足你办公需求

在这个信息化时代&#xff0c;软件已经成为我们办公和生活的必备工具。然而&#xff0c;市面上的大部分国产软件都需要付费才能使用&#xff0c;给我们的经济负担增加了不少。幸运的是&#xff0c;国内有一些良心软件&#xff0c;它们质量上乘&#xff0c;功能强大&#xff0c;…

2023牛客网秋招国内大厂最牛的 Java 面试八股文合集(全彩版)

秋收即将来临&#xff0c;找工作的小伙伴比比皆是&#xff0c;很对小伙伴早早的就开始储备技术&#xff0c;准备秋招面试了。 为了帮助小伙伴更好的应对面试&#xff0c;我拉来十几个大佬&#xff0c;汇总一线大厂的情况&#xff0c;给你整了一套超全的面试资料&#xff1a; 16…

深度学习项目实战二: LetNet5网络结构搭建

深度学习项目实战二: LetNet5网络结构搭建 文章目录 深度学习项目实战二: LetNet5网络结构搭建@[TOC](文章目录)一、卷积基本运算公式二、LetNet5网络1. 网络结构![在这里插入图片描述](https://img-blog.csdnimg.cn/0008fe6e5886414eac09eed49556ad99.png)2. 导入相关包3. 代码…

熔断与降级 Hystrix

一、Hystrix(豪猪)简介 1、Hystrix的设计目的 &#xff08;1&#xff09;对依赖服务调用时出现的调用延迟和调用失败进行控制和容错保护。 &#xff08;2&#xff09;阻止某一个依赖服务的故障在整个系统中蔓延&#xff0c;服务A->服务B->服务C&#xff0c;服务C故障了…

四、交换网络实验4——单臂路由配置

更多网络基础内容可见: 网络基础学习目录及各章节指引 4.6.4 配置单臂路由器 实验目的 学习配置单臂路由 实验工具 Cisco Packet Tracer 实验环境 安装模拟器的Windows系统 实验步骤 第一步:根据拓扑配置基本信息

【Linux修炼】开发工具使用

&#x1f307;个人主页&#xff1a;平凡的小苏 &#x1f4da;学习格言&#xff1a;命运给你一个低的起点&#xff0c;是想看你精彩的翻盘&#xff0c;而不是让你自甘堕落&#xff0c;脚下的路虽然难走&#xff0c;但我还能走&#xff0c;比起向阳而生&#xff0c;我更想尝试逆风…

无人机遥感在农林信息提取中的实现方法与GIS融合制图教程

详情点击链接&#xff1a;无人机遥感在农林信息提取中的实现方法与GIS融合制图 遥感技术作为一种空间大数据手段&#xff0c;能够从多时、多维、多地等角度&#xff0c;获取大量的农情数据。数据具有面状、实时、非接触、无伤检测等显著优势&#xff0c;是智慧农业必须采用的重…

Vue指令案例

案例需求&#xff1a; 将Vue数据模型中的数据以表格的形式渲染展示 具体代码如下&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-wid…

《MySQL》对表进行操作(DDL语句)

文章目录 &#x1f4a1;创建表&#x1f4a1;修改表&#x1f4a1;删除表 在了解下列语句前&#xff0c;先掌握一下指令 # 查看表内容 desc [表名] # 详细查看表内容 show create table [表名] \G&#x1f4a1;创建表 # 创建表 create table [表名] ([字段1] [类型1],[字段2] […

ChatGPT实战:高考志愿填报

近期&#xff0c;随着各地陆续发布高考成绩&#xff0c;高考志愿填报市场随之升温&#xff0c;“高报师”再次成为“香饽饽”。填报志愿对中学生来说太难&#xff0c;在一个懵懂的年纪做这样一个决策&#xff0c;份量是比较重的。当普通人没很多的信息做参考的时候&#xff0c;…

pytorch快速入门中文——01

PyTorch 深度学习&#xff1a;60分钟快速入门 原文&#xff1a;https://pytorch.org/tutorials/beginner/deep_learning_60min_blitz.html 作者&#xff1a; Soumith Chintala https://www.youtube.com/embed/u7x8RXwLKcA 什么是 PyTorch&#xff1f; PyTorch 是基于以下两个…

Linux历史及环境搭建(VMware搭建CentOS7环境以及使用XShell连接Vmware)

Linux历史及环境搭建 1.Linux历史1.1 UNIX发展的历史1.2 Linux发展历史1.2.1 开源1.2.2 官网1.2.3 发行版本 2.VMware配置CentOS7环境2.1 CentOS下载2.2 配置环境2.3 切换国内阿里源2.4 无图形化界面开机2.5 使用XShell连接VMware 结语 1.Linux历史 在这里简要介绍Linux的发展…

AI医疗。

随着技术的发展&#xff0c;人工智能&#xff08;AI&#xff09;已经渗透到了我们生活的许多领域&#xff0c;包括凭其强大的预测和分析能力已经走入了医疗卫生领域。特别是在使用OpenAI的GPT-4技术的chatbot&#xff0c;如chatGPT和GPT-4等&#xff0c;已经成为了给医疗行业注…

Bert

参考资料&#xff1a; 《机器学习》李宏毅 1 Bert 是怎么运作的&#xff1f; Bert 是一种自监督学习&#xff08;Self-supervised Learning&#xff09;模型。Bert 的目标是 pre-train 出一个能够理解语义的多功能语言模型&#xff0c;使之能够在特定任务上只学习较少的带标…

MAVEN的学习

MAVEN的作用是什么&#xff1f; 依赖管理&#xff1a;方便快捷的管理项目的资源&#xff08;jar包&#xff09;&#xff0c;避免版本冲突问题统一项目结构&#xff1a;提供标准、统一的项目结构项目构建&#xff1a;标准跨平台&#xff08;Linux、windows、MacOS&#xff09;的…

幂等性及解决方案

什么是幂等性 幂等性简单的说就是相同条件下&#xff0c;一次请求和多次重复的请求&#xff0c;接口的执行结果是相同的。 什么情况下会出现幂等性问题呢&#xff1f; 前端重复提交表单&#xff1a;如用户在提交表单的时候&#xff0c;由于网络波动没有及时给用户做出提交成…

可信数据库大会,不见不散!

由中国信息通信研究院、中国通信标准化协会指导&#xff0c;中国通信标准化协会大数据技术标准推进委员会&#xff08;CCSA TC601&#xff09;、InfoQ 极客传媒联合主办的 2023 可信数据库发展大会将于今日在北京国际会议中心隆重召开。 本届大会以“自主 创新 引领”为主题…