這篇文章要跟大家介紹的內容是React中動畫不生效的原因分析,有著一定的參考價值,有需要的朋友可以參考一下。
專案中需要做這樣的一個元件
根據不同的數值,這個藍色的條所顯示的寬度不同。
這個其實很簡單,我只要根據資料動態的計算它的寬度,生成節點就行了。
其中的部分react程式碼如下
{data && data.length > 0 ? data.map((item, index) => ( <p> </p><p> <span>{item.name || item.label}</span> <span>{item.value}</span> </p> <p> <span></span> </p> )) : null}
這樣就實現如上圖所示的功能顯示,但是現在又有個需求,就是需要那個藍色的條剛載入的時候動起來。
transition
我一開始就想到了css的transition屬性,然後把它加入程式碼中
.inner { width: 0; transition: width 0.6s ease; }
可是這個動畫並沒有生效。
然後我就回過頭來思考為什麼它沒有生效?
transition這個屬性只有在width屬性改變的時候才會產生作用。現在只能說明span的width並沒有改變。
這時候就要說到我的這段程式碼了,它是一邊計算寬度,一邊渲染節點的,也就是說它節點生成的時候,寬度就已經定好了。所以transition當然不會生效了
現在我要怎麼改進這段程式碼讓動畫生效呢?
我只能先讓節點產生好,然後再改變它的寬度了。
這就想到了react中的ref屬性了,這個屬性接受字串或函數,而這個函數在節點載入完成後或是節點銷毀前都會觸發,然後我就可以透過這個函數傳回的參數,操作這個節點改變寬度了,這正是我所需要的。
有了思路,開始改進程式碼。
{data && data.length > 0 ? data.map((item, index) => ( <p> </p><p> <span>{item.name || item.label}</span> <span>{item.value}</span> </p> <p> <span> { if (n && n.style) { n.style.width = `${getWidth(item.value)}px`; } }} /> </span></p> )) : null}
然後開啟瀏覽器看結果,果然成功了。
效果如下。
相關推薦:
以上是React中動畫不生效的原因分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

调用方法:1、类组件中的调用可以利用React.createRef()、ref的函数式声明或props自定义onRef属性来实现;2、函数组件、Hook组件中的调用可以利用useImperativeHandle或forwardRef抛出子组件ref来实现。

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

怎么调试React源码?下面本篇文章带大家聊聊多种工具下的调试React源码的方法,介绍一下在贡献者、create-react-app、vite项目中如何debugger React的真实源码,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

React 自定义 Hook 是一种将组件逻辑封装在可重用函数中的方式,它们提供了一种在不编写类的情况下复用状态逻辑的方式。本文将详细介绍如何自定义封装 hook。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SublimeText3漢化版
中文版,非常好用

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版