相关文章推荐
豁达的铁链  ·  振毕高呼_百度百科·  1 年前    · 
精明的大白菜  ·  2021广州车展:广汽三菱阿图柯AIRTRE ...·  2 年前    · 
耍酷的甘蔗  ·  唤醒心中热血,“赛道级性能SUV”星途凌云S ...·  2 年前    · 
面冷心慈的饺子  ·  广东“坟爷”骗贷案重审:罪名改为骗取贷款罪, ...·  2 年前    · 
暴走的大熊猫  ·  影帝X影帝-番外-兽人世界9·  2 年前    · 
Code  ›  Fabric.js 清空画布,甚至连画布元素也给你干掉😏开发者社区
canvas fabric canvas元素
https://cloud.tencent.com/developer/article/2119020
深情的香槟
2 年前
作者头像
德育处主任
0 篇文章

Fabric.js 清空画布,甚至连画布元素也给你干掉😏

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > 前端数据可视化 > Fabric.js 清空画布,甚至连画布元素也给你干掉😏

Fabric.js 清空画布,甚至连画布元素也给你干掉😏

作者头像
德育处主任
发布 于 2022-09-23 10:13:13
1.5K 0
发布 于 2022-09-23 10:13:13
举报

本文简介

点赞 + 关注 + 收藏 = 学会了

我们可以在 Canvas 上绘制图形,同样也可以将画布上的所有内容都清空掉。

01.gif
01.gif

本文主要聊聊:

  • 在 fabric.js 中如何清空画布;
  • 和原生 canvas 对比, fabric.js 到底有多方便;
  • 销毁 fabrci.js 创建的画布;
  • 把 canvas 元素也销毁掉;

原生 Canvas 清空画布

某些项目中(比如绘图工具)清空画布是一个基础功能。

在原生 Canvas 中要清空画布,需要使用获取画布的宽高。

<canvas id="c" width="300" height="300" style="border: 1px solid #ccc;"></canvas>
<script>
  const cnv = document.getElementById('c')
  const ctx = cnv.getContext('2d')
  ctx.fillStyle = 'pink' // 设置填充颜色
  ctx.fillRect(50, 50, 200, 200) // 填充矩形
  ctx.clearRect(0, 0, cnv.width, cnv.height) // 清空矩形
</script>

上面的代码可以把清空画布,但如果没有了解过 canvas ,或者不熟悉的工友,看到上面的代码可能会有点懵。

但没关系,本文不是讲原生 canvas 的,如果想入门 canvas 可以移步到 《Canvas 从入门到劝朋友放弃(图解版)》

fabric.js清空画布:clear

fabric.js 提供了 clear 方法,可以直接清空画布。

为了演示这个方法,我在画布上创建了一个三角形。

02.gif
02.gif
<button onclick="handleClear()">清空画布</button>
  <canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
  <script>
    // 初始化画布
    let canvas = new fabric.Canvas('canvasBox')
    // 三角形
    const triangle = new fabric.Triangle({
      top: 100,
      left: 50,
      width: 80, // 底边宽度
      height: 100, // 底边到定点的距离
      fill: 'blue',
    // 将三角形添加到画布中
    canvas.add(triangle)
    // 清空画布
    function handleClear() {
      canvas.clear()
  </script>

fabric.js 的代码就非常语义化了。就算你没了解过 fabric.js 也应该能猜出个大概。

上面的例子中,当点击按钮时就调用 canvas.clear() 直接清空了画布。在这个过程中你根本不需要了解画布的宽高。

使用 clear 方法只会清空画布上的内容,并不会销毁画布。

03.gif
03.gif

可以看到清空画布后, fabric.js 的默认操作还是在的(可以框选),这证明画布只是被清空了,并没有被销毁。

销毁 fabric 实例:dispose

除了使用 clear 方法清空画布外, fabric.js 还提供了另一个更强的方法: dispose

dispose 方法可以把 fabric.js 创建出来的实例销毁掉。

通常在页面销毁前会用到 dispose 方法。

尤其是在单页面应用中,离开页面前要调用该方法,不然重新进入这个页面,有可能会重新实例化画布。

如果离开页面前没销毁画布,在某些特殊情况下可能会出现意外效果。

04.gif
04.gif
<button onclick="handleDispose()">dispose</button>
<canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
<script>
  // 初始化画布
  let canvas = new fabric.Canvas('canvasBox')
  // 三角形
  const triangle = new fabric.Triangle({
    top: 100,
    left: 50,
    width: 80, // 底边宽度
    height: 100, // 底边到定点的距离
    fill: 'blue',
  // 将三角形添加到画布中
  canvas.add(triangle)
  // 清空画布
  function handleDispose() {
    canvas.dispose() // 清除一个画布元素并删除所有事件侦听器
</script>

从上面的例子中可以看到,在销毁画布的时候, canvas 元素也获得了自由(没被 fabric.js 劫持了)。

可以对比一下

05.png
05.png

上图是 dispose 前。

06.png
06.png

上图是使用 dispose 销毁画布之后。

将 Canvas 元素也干掉:借助 getElement

如果想在销毁画布后,将 canvas 元素也移除掉,可以借助 getElement 获取当前画布元素,然后使用 dispose 销毁 fabric 创建出来的实例,再用 remove 方法把画布干掉就行。

07.gif
07.gif
<button onclick="getElement()">删除画布</button>
<canvas id="canvasBox" width="400" height="400" style="border: 1px solid #ccc;"></canvas>
<script>
  // 初始化画布
  let canvas = new fabric.Canvas('canvasBox')
  // 三角形
  const triangle = new fabric.Triangle({
    top: 100,
    left: 50,
    width: 80, // 底边宽度
    height: 100, // 底边到定点的距离
    fill: 'blue',
  // 将三角形添加到画布中
  canvas.add(triangle)
  // 返回与此实例对应的画布元素
  function getElement() {
    let el = canvas.getElement()
 
推荐文章
豁达的铁链  ·  振毕高呼_百度百科
1 年前
精明的大白菜  ·  2021广州车展:广汽三菱阿图柯AIRTREK静态解析-手机新浪汽车
2 年前
耍酷的甘蔗  ·  唤醒心中热血,“赛道级性能SUV”星途凌云S 4月19日即将上市_我家汽车网
2 年前
面冷心慈的饺子  ·  广东“坟爷”骗贷案重审:罪名改为骗取贷款罪,由无期改判6年
2 年前
暴走的大熊猫  ·  影帝X影帝-番外-兽人世界9
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号