如何在React中寫一個Animation組件并為組件進入和離開加上動畫/過度效果

這篇文章主要為大家展示了“如何在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

組件設計

為了使得組件簡單易用、低耦合,我們期望如下方式來調用組件:

屬性名類型描述
isShowBoolean子元素顯示或隱藏控制
nameString指定一個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。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

外貿網站建設
主站蜘蛛池模板: 国产丝袜无码一区二区三区视频| 久久精品九九热无码免贵| 国产激情无码一区二区app| 少妇性饥渴无码A区免费 | 日韩人妻系列无码专区| 国产精品无码2021在线观看| 成年午夜无码av片在线观看| 无码中文字幕乱在线观看| 黄色成人网站免费无码av| 高h纯肉无码视频在线观看| 无码丰满熟妇一区二区| 亚洲av无码不卡一区二区三区| 亚洲AV无码AV吞精久久| 国产在线无码视频一区二区三区| 午夜不卡无码中文字幕影院| 亚洲AV无码一区二区三区电影| 亚洲AV无码乱码精品国产| 日韩精品无码专区免费播放| 日韩精品无码Av一区二区| 精品无码无人网站免费视频| 黑人无码精品又粗又大又长| 无码少妇一区二区浪潮免费| 亚洲AV无码一区二区二三区入口| 亚洲av无码天堂一区二区三区| 精品欧洲av无码一区二区| 亚洲ⅴ国产v天堂a无码二区| 亚洲 另类 无码 在线| 无码中文在线二区免费| 国产成人无码AV麻豆| 免费无遮挡无码永久视频| 波多野结AV衣东京热无码专区| 精品国产AV无码一区二区三区| 亚洲av无码专区首页| 亚洲精品GV天堂无码男同| 久久亚洲精品无码VA大香大香| 性无码免费一区二区三区在线| 日韩精品无码免费专区午夜| 国产精品无码永久免费888| 白嫩无码人妻丰满熟妇啪啪区百度| 亚洲AV无码AV吞精久久| 人妻少妇精品无码专区漫画|