react-transition-group动画库Transition组件使用

栏目: IOS · Android · 发布时间: 5年前

内容简介:这个库包括3个组件:该属性可以对元素里面的一个属性设置过渡动画,比如:祥见:

react-transition-group动画库

这个库包括3个组件: Transition,CSSTransition,TransitonGroup ,今天做项目刚好用到了Transition组件,记录一下使用过程中的总结,另外两个组件用到了再做介绍。或者移步到 react 官网动画库(react-transition-group)的新写法

CSS3的transition属性

该属性可以对元素里面的一个属性设置过渡动画,比如: transition: width 2s;

祥见: CSS3 transition 属性

transition-property
transition-duration
transition-timing-function
transition-delay

Transition的属性

元素动画在出现和消失时各有3个阶段,可以为这些属性绑定自定义函数:

  • onEnter:进入(出现)开始时执行
  • onEntering:进入(出现)过程中执行
  • onEntered:进入(出现)结束执行
  • onExit:离开(消失)时执行
  • onExiting:离开(消失)过程中执行
  • onExited:离开(消失)结束执行

其他属性介绍:

  • addEndListener: 属性可以监听出现的3个阶段执行完成或消失的3个阶段执行完成时执行该函数监听的自定义函数。
  • unmountOnExit: 为true 代表退出的时候移除dom,也就是该元素dom动画执行完后直接删除该元素节点
  • appear: 渲染的时候就直接执行动画,默认false
  • enter: 设为true后,动画进入(出现)的三个阶段,前两个阶段 onEnter,onEntering 先执行,然后延迟一段时间再执行 onEntered ,可以简单的理解为动画进入(出现)时有个延迟
  • exit: 设为true后,动画离开(消失)的三个阶段,前两个阶段 onExit,onExiting 先执行,然后延迟一段时间再执行 onExited ,可以简单的理解为动画离开(消失)时有个延迟
  • timeout: 为上面的 appear,enter,exit 设置延迟时间
  • in :动画进入(出现),离开(消失)交替执行,点一下动画生效,再点一下动画失效

使用方法

<Transition> 标签可是设置上面那些属性。标签内容包裹一个箭头函数,该函数有一个参数state(参数名随意设置),返回值就是要实现动画效果的元素,该元素可以设置style样式。

案例一

此案例是我测试的案例,通过下拉框的透明度实现一个下拉框出现和消失的效果:

import React from 'react';
import {connect} from 'react-redux';
//受到路由管控
import {withRouter} from 'react-router-dom';
import {Icon} from 'antd';
//过渡动画
import Transition from 'react-transition-group/Transition';
//duration设置延迟时间,下面的timeout属性使用
const duration = {
         appear:3000,
         enter: 3000,
         exit: 3000};
//默认样式
const  defaultStyle = {
        //ease-in-out规定以慢速开始和结束的过渡效果
        transition:`opacity ${3000}ms ease-in-out`,
        opacity:0,
    };
//过渡样式
const  transitionStyles = {
        //进入时2,3阶段动画,如果设置了延迟时间,会发现出现时立即透明度百分之"0.5",然后三秒后透明度才为"1"
        //因为延迟时间timeout属性设置的``enter:3000``会在第三阶段生效
        entering:{opacity: 0.5},
        entered:{opacity:1},
        //离开时2,3阶段
        exiting: {opacity: 0.5},
        exited: {opacity: 0}
    };

// 三个进入状态的事件,可以做你想做的事情
let onEnter = (node, isAppearing) => {
    console.log(isAppearing,node, 'onEnter')
};
let onEntering = (node, isAppearing) => {
    console.log(isAppearing,node, 'onEntering')
};
let onEntered = (node, isAppearing) => {
    console.log(isAppearing,node,'onEntered')
};

//测试动画执行过程,何时结束
let done =() => {
    console.log('结束了')
};

// 三个退出的状态的事件
let onExit = (node) => {
    console.log('onExit')
};
let onExiting = (node) => {
    console.log('onExiting')
};
let onExited = (node) => {
    console.log('onExited',node)
};

let addaddEndListener = (node) => { //原生时间transition运动的事件
    node.addEventListener('transitionend', this.done, false);
};

class NavTop extends React.Component{
    constructor(props,context){
        super(props,context);
        this.state = {
          in:false
        };
    }

    render() {
        return <header className='headerNavBox'>
            {/*首页导航*/}
            <div className='homeBox'>
                <div className='baseBox clearfix' >
                    <h1 className='logo' >大鱼资源网</h1>
                    <Icon className='icon' type='bars' style={{
                    fontSize:'.6rem'
                    }} onClick={ev=>{
                        this.setState({
                            in:!this.state.in
                        })
                    }} />
                </div>
                {/*下拉条,过渡动画*/}
                <Transition
                    onEnter={onEnter}
                    onEntering={onEntering}
                    onEntered={onEntered}

                    onExit={onExit}
                    onExiting={onExiting}
                    onExited={onExited}

                    addEndListener={this.addaddEndListener}//添加动画执行完后执行的函数
                    unmountOnExit={true}//动画消失后,元素dom节点也消失
                    appear={false}//组件渲染就出现动画
                    enter={true}//动画效果出现时延迟,默认是true
                    exit={true}//动画效果消失时延迟
                    timeout={duration}//设置延迟时间,准确的说应该是动画出现和消失的第三阶段延迟时间,因为前两个阶段会立即执行
                    in={this.state.in} >
                    {
                        state => {
                            //打印状态变化分别是onEnter,onEntering...等6种,通过此处可以看出延迟时间是在第三阶段生效,前两个阶段会立即执行
                            console.log(state,'###',{...defaultStyle, ...transitionStyles[state]}, '###');
                            return <ul className='filterBox' style={{
                                ...defaultStyle,
                                //根据state的变化,过渡动画的透明度随着变化
                                ...transitionStyles[state]
                            }} >
                                <li>全部课程</li>
                                <li>react课程</li>
                                <li>vue课程</li>
                                <li>小程序课程</li>
                            </ul>
                        }
                    }
                </Transition>
            </div>
        </header>;
    }
}

export default withRouter(connect()(NavTop));

案例一结束。

react-transition-group动画库Transition组件使用

案例二

//自己简单的封装了一个,该有的参数都由了,可以自行粘贴在自己的代码里面去试试。
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 例如<MyComponent className={`fade fade-${status}`} />
    return (
      <Transition 
        onEnter={this.onEnter}
        onEntering={this.onEntering}
        onEntered={this.onEntered}

        onExit={this.onExit}
        onExiting={this.onExiting}
        onExited={this.onExited}

        addEndListener={this.addaddEndListener} 
        in={inProp} 
        unmountOnExit={false} // 为true 代表退出的时候移除dom
        appear={true} // 为true  渲染的时候就直接执行动画,默认false,
        timeout={duration}
      >
        {
          state => {
            console.log(state, '###') //你可以很直观的看到组件加载和卸载时候的状态
            return(
              <div style={{
                ...defaultStyle,
                ...transitionStyles[state]
              }}>
                {this.props.children}
              </div>
            )
          }
        }
      </Transition>
    );
  }
}

案例二结束。

参考网址

官方案例

react官网动画库(react-transition-group)的新写法


以上所述就是小编给大家介绍的《react-transition-group动画库Transition组件使用》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

科技投资新时代:TMT投资方法、趋势与热点聚焦

科技投资新时代:TMT投资方法、趋势与热点聚焦

马军、宋辉、段迎晟 / 人民邮电出版社 / 2018-3 / 69.00

中国 TMT 行业(科技、媒体及通信)起步较晚但充满朝气。2017 年,TMT 板块的IPO 数量占到了总数的四分之一;对于投资者来说,投资 TMT 的收益非常可观。那么,TMT 的投资趋势如何? TMT 行业又有哪些投资热点? 本书立足于 TMT 投资现状,在介绍了 TMT 投资的基本概念之后,作者详细讲述了TMT 投资的基本研究方法、分析视角、整体行情及趋势分析,同时从行业视角分析了包括......一起来看看 《科技投资新时代:TMT投资方法、趋势与热点聚焦》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器