亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Fabric.js?樣式不更新解決方法案例

 更新時間:2023年02月14日 08:46:42   作者:德育處主任  
這篇文章主要為大家介紹了Fabric.js?樣式不更新解決方法案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

本文簡介

不知道你有沒有遇到過在使用 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() 的方式刷新畫布。

從控制臺輸出的數(shù)據(jù)來看,矩形確實是變紅了,但從視覺上看畫布中的矩形卻還是粉色。

其實正確的做法是使用 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 樣式更新的資料請關注腳本之家其它相關文章!

相關文章

  • 微信小程序 教程之事件

    微信小程序 教程之事件

    這篇文章主要介紹了微信小程序 事件的相關資料,并附實例代碼,需要的朋友可以參考下
    2016-10-10
  • JS開發(fā) 富文本編輯器TinyMCE詳解

    JS開發(fā) 富文本編輯器TinyMCE詳解

    這篇文章主要介紹了Java開發(fā) 富文本編輯器TinyMCE詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07
  • 微信小程序 跳轉傳參數(shù)與傳對象詳解及實例代碼

    微信小程序 跳轉傳參數(shù)與傳對象詳解及實例代碼

    這篇文章主要介紹了微信小程序 跳轉傳參數(shù)與傳對象詳解及實例代碼的相關資料,需要的朋友可以參考下
    2017-03-03
  • 微信小程序頁面間通信的5種方式

    微信小程序頁面間通信的5種方式

    這篇文章主要介紹了微信小程序頁面間通信的5種方式,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • JavaScript 原型與原型鏈詳情

    JavaScript 原型與原型鏈詳情

    這篇文章主要介紹了JavaScript 原型與原型鏈,JavaScript常被描述為一種基于原型的語言,對象以其原型為模板、從原型繼承屬性和放法。原型對象也可能擁有原型,并從中繼承屬性和方法,一層一層以此類推。這種關系常被稱為原型鏈,帶著簡單的了解看看下文內容具體介紹吧
    2021-10-10
  • 原生js實現(xiàn)鼠標滑過播放音符方法詳解

    原生js實現(xiàn)鼠標滑過播放音符方法詳解

    本文使用原生js的AudioContext接口實現(xiàn)一個劃過菜單播放天空之城的鼠標特效,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 微信小程序 密碼輸入(源碼下載)

    微信小程序 密碼輸入(源碼下載)

    這篇文章主要介紹了微信小程序 密碼輸入(源碼下載)的相關資料,需要的朋友可以參考下
    2017-06-06
  • 微信小程序 網(wǎng)絡API 上傳、下載詳解

    微信小程序 網(wǎng)絡API 上傳、下載詳解

    這篇文章主要介紹了微信小程序 網(wǎng)絡API 上傳、下載詳解的相關資料,需要的朋友可以參考下
    2016-11-11
  • 微信小程序 詳解Page中data數(shù)據(jù)操作和函數(shù)調用

    微信小程序 詳解Page中data數(shù)據(jù)操作和函數(shù)調用

    這篇文章主要介紹了微信小程序 詳解Page中data數(shù)據(jù)操作和函數(shù)調用的相關資料,需要的朋友可以參考下
    2017-01-01
  • 詳解 TypeScript 枚舉類型

    詳解 TypeScript 枚舉類型

    這篇文章主要介紹了TypeScript 枚舉類型,TypeScript 在 ES 原有類型基礎上加入枚舉類型,使得在 TypeScript 中也可以給一組數(shù)值賦予名字,這樣對開發(fā)者比較友好,可以理解枚舉就是一個字典,文章內容圍繞TypeScript 枚舉類型展開內容,需要的朋友可以參考一下
    2021-10-10

最新評論