前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Fabric.js 设置容器类名要注意这几点

Fabric.js 设置容器类名要注意这几点

作者头像
德育处主任
发布2022-09-23 10:26:25
1.1K0
发布2022-09-23 10:26:25
举报
文章被收录于专栏:前端数据可视化

本文简介

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

fabric.js 创建画布时,fabric.js 会在 canvas 元素外包一层 div 容器。

如果想方便设置容器样式或者想通过 js 控制该容器,可以先给容器一个类名。

本文主要讲如何给包装容器设置类名相关注意事项

设置容器类名

在使用 fabric.js 创建画布时就可以 通过 containerClass 设置包装容器的类名

代码语言:javascript
复制
<canvas id="canvasBox"></canvas>
<script>
  // 创建画布
  let canvas = new fabric.Canvas('c', {
    containerClass: 'ccc'
  })
</script>

我这里随便命名,使用了 ccc

此时打开控制台就可以看到外层包装容器的类名是 ccc

可以再配合 css 设置一些样式。

代码语言:javascript
复制
<style>
  .ccc {
    border: 1px solid pink;
  }
</style>

<canvas id="canvasBox"></canvas>

<script>
  // 创建画布
  let canvas = new fabric.Canvas('c', {
    containerClass: 'ccc'
  })
</script>

使用 fabric.js 的话,建议使用该方法设置包装容器的类名。

注意事项

虽然设置包装容器类名很方便,但也存在一些注意事项。

容器有默认类名

如果没使用 containerClass 设置包装容器类名,fabric.js 会将容器的类名设置为 canvas-container

不建议用css设置宽高

如果用 css 设置容器的宽高,还需要使用 !important 才会生效。因为 fabric.js 会将默认宽高绑定在元素的 style 上,变成内联样式。

但即使是使用 !important 提高样式权重,只会改变容器宽高,并不会改变画布宽高。所以还需要设置画布宽高。

代码语言:javascript
复制
<style>
  .ccc {
    border: 1px solid pink;
    width: 500px !important;
    height: 300px !important;
  }

  .ccc canvas {
    width: 500px !important;
    height: 300px !important;
  }
</style>

<canvas id="canvasBox"></canvas>

<script>
  let canvas = new fabric.Canvas('canvasBox', {
    containerClass: 'ccc'
  })
</script>

canvas 中不推荐使用 css 的方式设置画布宽高,因为这样做会导致画布内容变形。

比如我在画布中添加一个正方形,这么一操作就不是正方形了。

代码语言:javascript
复制
<style>
  .ccc {
    border: 1px solid pink;
    width: 500px !important;
    height: 300px !important;
  }

  .ccc canvas {
    width: 500px !important;
    height: 300px !important;
  }
</style>

<canvas id="canvasBox"></canvas>

<script>
  let canvas = new fabric.Canvas('canvasBox', {
    containerClass: 'ccc'
  })

  let rect = new fabric.Rect({
    width: 100,
    height: 100,
    top: 10,
    left: 10
  })

  canvas.add(rect)
</script>

如需设置画布宽高,可参考 《Fabric.js 3个api设置画布宽高》

不建议设置容器定位模式

fabric.js 在初始化画布时,会将容器的 position 设置成 relative

将里面的2个 canvas 元素的 position 设置成 absolute

没特殊需求的话,应该尊重 fabric.js 的这个设定。

不建议设置容器的padding

如果只是设置了容器的 padding 其实没多大意义。

因为内部的两个 canvas 元素都使用了绝对定位 ( relative ) 的定位模式,所以这样操作没啥意义。

代码仓库

Fabric.js 设置容器类名

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-09-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 本文简介
  • 设置容器类名
  • 注意事项
    • 容器有默认类名
      • 不建议用css设置宽高
        • 不建议设置容器定位模式
          • 不建议设置容器的padding
          • 代码仓库
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档