Fabric.js 样式不更新怎么办?

news/2025/1/15 12:21:45/

本文简介

带尬猴,我嗨德育处主任


不知道你有没有遇到过在使用 Fabric.js 时无意中一些骚操作修改了元素的样式,但刷新画布却没更新元素样式?

如果你也遇到同样的问题的话,可以尝试使用本文的方法。



是否需要重新绘制

我先举个例子。

file

<canvas id="c" style="border: 1px solid #ccc;"></canvas><script>
let canvas = new fabric.Canvas('c')// 矩形 - 亮粉色
let rect = new fabric.Rect({left: 50,top: 30,width: 80,height: 60,fill: 'hotpink'
})canvas.add(rect)setTimeout(() => {console.log(rect.fill) // 输出 'hotpink'rect.fill = 'red'console.log(rect.fill) // 输出 'red'canvas.renderAll() // 刷新画布
}, 1000)</script>

在这个例子中,页面运行1秒后,我想通过 rect.fill = 'red' 的方式将画布中的矩形修改成红色。

修改完成后在控制台输出当前矩形的颜色,然后再通过 canvas.renderAll() 的方式刷新画布。

从控制台输出的数据来看,矩形确实是变红了,但从视觉上看画布中的矩形却还是粉色。


其实正确的做法是使用 rect.set('fill', 'red') 去修改矩形颜色,set() 方法会通知画布要刷新样式。

但如果你坚持使用 rect.fill = 'red' 的方式去修改也不是不行,此时需要将矩形的 statefullCache 设置为 true,矩形就会自动检测属性的值的更新。


file

// 省略部分代码let rect = new fabric.Rect({left: 50,top: 30,width: 80,height: 60,fill: 'hotpink',statefullCache: true // 自动检测更新
})canvas.add(rect)setTimeout(() => {console.log(rect.fill) // 输出 'hotpink'rect.fill = 'red'console.log(rect.fill) // 输出 'red'canvas.renderAll()
}, 1000)

但并不是所有情况都适合将 statefullCache 设为 true

官方文档也有介绍到:

statefullCache: Boolean

When true, object properties are checked for cache invalidation. In some particular situation you may want this to be disabled ( spray brush, very big, groups) or if your application does not allow you to modify properties for groups child you want to disable it for groups. default to false since 1.7.0


说了这么多,最后我还是推荐通过 set() 方法修改元素的属性。



代码仓库

⭐ 是否需要重新绘制缓存的副本



推荐阅读

👍《Fabric.js 动态设置字号大小》

👍《Fabric.js 监听元素相交(重叠)》

👍《Fabric.js 限制边框宽度缩放》

👍《Fabric.js 保存自定义属性》

👍《Fabric.js 元素被遮挡的部分也可以操作》

👍《Fabric.js 从入门到膨胀》


点赞 + 关注 + 收藏 = 学会了 代码仓库


http://www.ppmy.cn/news/1180187.html

相关文章

sourcetree Incorrect username or password (access token)

sourcetree报错 sourcetree Incorrect username or password (access token) 右键sourcetree找到文件所在目录 回到上一级&#xff0c;一般为AppData\Local 在AppData\Local下找到名为Atlassian的文件夹 在里面找到passwd和userhosts文件&#xff0c;并删掉 回到sourcetree再次…

Kamailio statsd模块测试

Kamailio statsd模块测试 准备statsd服务器 git克隆 cd /usr/local git clone https://github.com/myoperator/grafana-graphite-statsd.git cd grafana-graphite-statsd make prep # 创建log目录修改docker-compose.yml&#xff0c;给statsd增加一个环境变量STATSD_DEBUGtr…

针对Java API格式

接口样式 /order/order/detail/{id} 小程序封装请求 //原 // getPurchaseDetail: (data) > request(/order/order/detail, GET, data) // -- 飘点符号不一致//现采购详情 getPurchaseDetail: (data) > request(/order/order/detail/${data}, GET, data),// 请求a…

深度学习| U-Net网络

U-Net网络 基础知识和CNN的关系反卷积ReLU激活函数 U-Net入门U-Net网络结构图为什么需要跳跃连接U-Net的输入U-Net的应用 基础知识 理解U-Net网络结构需要相关知识点。 和CNN的关系 U-Net也是CNN&#xff08;Convolutional Neural Network&#xff0c;卷积神经网络&#xff…

美摄AR人像美颜,全新视觉体验

企业越来越重视通过视觉媒体来提升品牌形象和吸引客户。然而&#xff0c;传统的摄影技术往往无法满足企业对于高质量、个性化视觉内容的需求。这时&#xff0c;美摄AR人像美颜解决方案应运而生&#xff0c;它以其独特的技术和优势&#xff0c;为企业带来了全新的视觉体验。 美…

Windows server服务器允许多用户远程的设置

在Windows Server上允许多用户同时进行远程桌面连接&#xff0c;您需要配置远程桌面服务以支持多用户并确保许可证和授权允许多用户连接。以下是在Windows Server上允许多用户远程桌面连接的步骤&#xff1a; 注意&#xff1a;这些步骤适用于 Windows Server 2012、Windows Ser…

AI时代中小企业算力需求爆发,惠普发布新品战99 Monster满血高算工作站

第17届DEMO CHINA创新中国峰会10月25日至26日在北京举行&#xff0c;吸引了国内众多优秀创新创业项目的积极参与。作为本届DEMO CHINA独家战略合作伙伴&#xff0c;惠普在大会上正式发布战家族新品战99 Monster满血高算工作站&#xff0c;满足AI时代中小企业对于算力的爆发式需…

MySQL初始化之后启动报错(mysqld: Table ‘mysql.plugin‘ doesn‘t exist)

报错场景 初始化之后&#xff0c;服务无法启动。错误日志error-log 报错如下&#xff1a;&#xff08;mysql库下的系统表不存在&#xff09; 2023-10-26T06:03:08.150163-00:00 1 [System] [MY-013576] [InnoDB] InnoDB initialization has started. 2023-10-26T06:03:08.496…