這篇文章主要為大家展示了“如何在React中寫一個Animation組件并為組件進入和離開加上動畫/過度效果”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何在React中寫一個Animation組件并為組件進入和離開加上動畫/過度效果”這篇文章吧。
我們提供的服務有:成都做網站、成都網站建設、成都外貿網站建設、微信公眾號開發、網站優化、網站認證、聞喜ssl等。為上千余家企事業單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的聞喜網站制作公司
問題
在單頁面應用中,我們經常需要給路由的切換或者元素的掛載和卸載加上過渡效果,為這么一個小功能引入第三方框架,實在有點小糾結。不如自己封裝。
思路
原理
以進入時 opacity: 0 --> opacity: 1 ,退出時 opacity: 0 --> opacity: 1 為例
元素掛載時
1.掛載元素dom
2.設置動畫 opacity: 0 --> opacity: 1
元素卸載時
1.設置動畫 opacity: 0 --> opacity: 1
2.動畫結束后卸載dom
組件設計
為了使得組件簡單易用、低耦合,我們期望如下方式來調用組件:
屬性名 | 類型 | 描述 |
---|---|---|
isShow | Boolean | 子元素顯示或隱藏控制 |
name | String | 指定一個name,動畫進入退出時的動畫 |
在 App.jsx 里調用組件:
通過改變isShow的值來指定是否顯示
// App.jsx // 其他代碼省略 import './app.css'; <Animation isShow={isShow} name='demo'> <div class='demo'> demo </div> </Animation> // 通過改變isShow的值來指定是否顯示 在 App.css 里指定進入離開效果: // 基礎樣式 .demo { width: 200px; height: 200px; background-color: red; } // 定義進出入動畫 .demo-showing { animation: show 0.5s forwards; } .demo-fading { animation: fade 0.5s forwards; } // 定義動畫fade與show @keyframes show { from { opacity: 0; } to { opacity: 1; } } @keyframes fade { from { opacity: 1; } to { opacity: 0; } }
根據思路寫代碼
// Animation.jsx import { PureComponent } from 'react'; import './index.css'; class Animation extends PureComponent { constructor(props) { super(props); this.state = { isInnerShow: false, animationClass: '', }; } componentWillReceiveProps(props) { const { isShow } = props; if (isShow) { // 顯示 this.show().then(() => { this.doShowAnimation(); }); } else { // 隱藏 this.doFadeAnimation(); } } handleAnimationEnd() { const isFading = this.state.animationClass === this.className('fading'); if (isFading) { this.hide(); } } show() { return new Promise(resolve => { this.setState( { isInnerShow: true, }, () => { resolve(); } ); }); } hide() { this.setState({ isInnerShow: false, }); } doShowAnimation() { this.setState({ animationClass: this.className('showing'), }); } doFadeAnimation() { this.setState({ animationClass: this.className('fading'), }); } /** * 獲取className * @param {string} inner 'showing' | 'fading' */ className(inner) { const { name } = this.props; if (!name) throw new Error('animation name must be assigned'); return `${name}-${inner}`; } render() { let { children } = this.props; children = React.Children.only(children); const { isInnerShow, animationClass } = this.state; const element = { ...children, props: { ...children.props, className: `${children.props.className} ${animationClass}`, onAnimationEnd: this.handleAnimationEnd.bind(this), }, }; return isInnerShow && element; } } export default Animation;
以上是“如何在React中寫一個Animation組件并為組件進入和離開加上動畫/過度效果”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!
當前文章:如何在React中寫一個Animation組件并為組件進入和離開加上動畫/過度效果
分享鏈接:http://m.kartarina.com/article38/ppppsp.html
成都網站建設公司_創新互聯,為您提供云服務器、移動網站建設、營銷型網站建設、品牌網站建設、網站內鏈、定制開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯