<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
不知道你有沒有遇到過在使用 Fabric.js
時無意中一些騷操作修改了元素的樣式,但重新整理畫布卻沒更新元素樣式?
如果你也遇到同樣的問題的話,可以嘗試使用本文的方法。
我先舉個例子。
<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
,矩形就會自動檢測屬性的值的更新。
// 省略部分程式碼 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 樣式更新的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45