摘要:一一個官網提供的動畫過度庫。安裝而官方提供的三個組建。下面來看一個例子效果是增加和刪除列表項中的一個,產生漸入漸失的效果說白了也就是多個或者組合的效果。
一、react-transition-group 一個官網提供的動畫過度庫。
搜索了網上關于react動畫的,很多的答案都是很久以前的了老版本了,而現在官方提供的是叫react-transition-group 它是以前兩個的合體版本,所以寫下這個記錄一下,同時也給一些需要的猿門給一些小的提示。
1、安裝
# npm npm install react-transition-group --save # yarn yarn add react-transition-group
而官方提供的三個組建Transition,CSSTransition,TransitonGroup。
Transition過渡組件(Transiton)允許您用一個簡單的聲明性API描述隨著時間的推移從一個組件狀態到另一個組件狀態的轉換。最常用的是用來動畫一個組件的安裝和卸載,但也可以用來描述在適當的過渡狀態。默認情況下,該組件不會更改其呈現的組件的行為,它只跟蹤組件的“進入”和“退出”的狀態。由你來為這些狀態定義效果。(翻譯)
實際的情況就是你如果只寫這個組件是沒有任何的效果的,就和你寫一個div一樣。所以你需要給他們賦予一些參數才可以。例如下面這個例子
//自己簡單的封裝了一個,該有的參數都由了,可以自行粘貼在自己的代碼里面去試試。 class Fade extends React.Component { constructor(props) { super(props); } done =() => { // console.log("結束了") } addaddEndListener = (node) => { //原生時間transition運動的事件 node.addEventListener("transitionend", this.done, false); } // 三個進入狀態的事件,可以做你想做的事情 onEnter = (node, isAppearing) => { console.log(isAppearing, "onEnter") } onEntering = (node, isAppearing) => { console.log(isAppearing, "onEntering") } onEntered = (node, isAppearing) => { console.log(isAppearing, "onEntered") } // 三個退出的狀態的事件 onExit = (node) => { console.log("onExit") } onExiting = () => { console.log("onExiting") } onExited = () => { console.log("onExited") this.props.self() } render() { const { in: inProp, dur} = this.props; const defaultStyle = { transition: `transform ${300}ms ease-in-out, opacity ${300}ms ease-in-out`, transform: "translateX(100px)", opacity: "0" } const transitionStyles = { entering: { transform: "translateX(100px)", opacity: "0"}, entered: { transform: "translateX(0px)", opacity: "1" }, exiting: {transform: "translateX(0px)", opacity: "1"}, exited: {transform: "translateX(0px)", opacity: "0"} }; const duration = { enter: 300, exit: 300, } // 上面的都是基本參數,樣式的轉變以及時間的設定,具體的可以看官網文檔 // 樣式也可以寫成className 例如return ( { state => { console.log(state, "###") //你可以很直觀的看到組件加載和卸載時候的狀態 return( ); } }{this.props.children}) } }
其中上面的狀態有四種:
entering entered exiting exited
組件的初始化狀態都停留在exited
上面就是寫的一個最基本的例子,下面是如何的調用
let num = 1; class Dnd extends React.Component { state = { ins: true, current: 1, dom:ceshi weizhi {num}} handle = (bool) => { this.setState({ test: !bool }) } end = () => { const that = this; num = num + 1; setTimeout(function () { that.setState({ test: true, dom:888888 {num}}) }, 500) } render () { const { location } = this.props const { test } = this.state; return () } } // 效果是每次點擊按鈕都會進行一次進場和出場的動畫。也可以自行衍生。 {this.state.dom}
這個組件大概就是這樣的,這樣適合寫一個tab類型的頁面,在切換的時候可以展示不同的domCSSTransition
此組件是在轉換的出現、進入、退出階段應用一對類名(也就是className),靠這個來激活CSS動畫。所以參數和平時的className不同,參數為:classNames
參數:(主要)in, timeout, unmountOnExit, classNames, 用法同Transition。看如下例子:
state = { star: false } ?
效果是點擊button 顯示星星,在點擊消失星星的動畫!
參數classNames="star", 組件會找對應狀態的className, 如下
.star { display: inline-block; margin-left: 0.5rem; transform: scale(1.25); } .star-enter { opacity: 0.01; transform: translateY(-100%) scale(0.75); } .star-enter-active { opacity: 1; transform: translateY(0%) scale(1.25); transition: all 300ms ease-out; } .star-exit { opacity: 1; transform: scale(1.25); } .star-exit-active { opacity: 0; transform: scale(4); transition: all 300ms ease-in; }
依次執行的順序是
1、星星顯示 對應的class為star-enter star-enter-active 動畫走完為star-enter-done 2、星星消失 對應的class為star-exit star-exit-active 動畫走完為star-exit-done
如果按照官網的解釋就是如下, 有興趣的可以自行去試一試。
classNames={{ appear: "my-appear", appearActive: "my-active-appear", enter: "my-enter", enterActive: "my-active-enter", enterDone: "my-done-enter, exit: "my-exit", exitActive: "my-active-exit", exitDone: "my-done-exit, }}
每個階段的鉤子函數同Transition.
TransitionGroup一看group就知道肯定是列表形態的動畫了!但是看了官網后知道,TransitionGroup不提供任何形式的動畫,具體的動畫取決與你包裹的Transition || CSSTransition的動畫,所以你可以在列表里面做出不同類型的動畫出來。下面來看一個例子
class List extends React.Component { constructor(props) { super(props); this.state = { items: [ { id: 1, text: "Buy eggs" }, { id: 2, text: "Pay bills" }, { id: 3, text: "Invite friends over" }, { id: 4, text: "Fix the TV" }, ] } } render() { const { items } = this.state; return (); } }{items.map(({ id, text }) => ( ))} {text}
css
.fade-enter { opacity: 0.01; } .fade-enter-active { opacity: 1; transition: opacity 500ms ease-in; } .fade-exit { opacity: 1; } .fade-exit-active { opacity: 0.01; transition: opacity 500ms ease-in; }
效果是增加和刪除列表項中的一個,產生漸入漸失的效果!說白了也就是多個Transition 或者CSSTransition組合的效果。
但是也提供一些參數
1、component default "div" 也就是TransitionGroup渲染出來的標簽為div,也可以就行更改,例如component="span" 渲染出來的就是span標簽了 2、children 相當于你給的組件,可以是字符串或者自定義組件等。 3、appear 寫在TransitionGroup里面相當于開啟或者禁止里面的Transition || CSSTransition 方便寫的作用
三個組件大概的特性就是這些。剩下的全靠自己去開發了!后續會錄入一些小的例子來講解,敬請期待。。。。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/95925.html
摘要:動畫庫這個庫包括個組件,今天做項目剛好用到了組件,記錄一下使用過程中的總結,另外兩個組件用到了再做介紹。規定完成過渡效果需要多少秒或毫秒。規定速度效果的速度曲線。參考網址官方案例官網動畫庫的新寫法 react-transition-group動畫庫 這個庫包括3個組件:Transition,CSSTransition,TransitonGroup,今天做項目剛好用到了Transitio...
摘要:動畫庫這個庫包括個組件,今天做項目剛好用到了組件,記錄一下使用過程中的總結,另外兩個組件用到了再做介紹。規定完成過渡效果需要多少秒或毫秒。規定速度效果的速度曲線。參考網址官方案例官網動畫庫的新寫法 react-transition-group動畫庫 這個庫包括3個組件:Transition,CSSTransition,TransitonGroup,今天做項目剛好用到了Transitio...
摘要:動畫的實現原理要實現動畫,究其根本,最終的落地依然是操作從而達到頁面呈現動畫的目的。 聲明: 當前為草稿階段。然后有人可以指引下怎么寫草稿文章么~ web動畫的實現原理 web動畫的實現,最終都是需要操作dom。CSS動畫,是給相應的dom元素添加動畫className ; JS動畫,則是通過定時器或其他手段,不斷更改dom元素屬性值,達到動畫的目的。 React動畫的實現原理 Re...
摘要:因為其組件只是根據提供的及屬性,生成動畫的數據,業務應用中拿到生成的數據后根據需要添加需要動畫的組件樣式。除了上述簡單的動畫應用,在復雜動畫的實現方面,表現非常優越。 WEB應用中動畫很重要 不管是web應用還是原生應用,也不論是PC端應用還是移動端應用,動畫都扮演了一個重要的角色。 盡管動畫并不會添加應用的實際動能,但一個好的動畫,一個流暢且優雅,選擇在恰當時機出現的動畫,能為應用增...
閱讀 716·2021-11-16 11:44
閱讀 3548·2019-08-26 12:13
閱讀 3243·2019-08-26 10:46
閱讀 2357·2019-08-23 12:37
閱讀 1189·2019-08-22 18:30
閱讀 2532·2019-08-22 17:30
閱讀 1841·2019-08-22 17:26
閱讀 2292·2019-08-22 16:20