最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

react-router 路由切换动画的实现示例

来源:动视网 责编:小采 时间:2020-11-27 22:03:09
文档

react-router 路由切换动画的实现示例

react-router 路由切换动画的实现示例:路由切换动画 因为项目的需求,需要在路由切换的时候,加入一些比较 zb 的视觉效果,所以研究了一下。把这些学习的过程记录下来,以便以后回顾。同时也希望这些内容能够帮助一些跟我一样的菜鸟,让他们少走些坑。可能我对代码的表述不是很到位,希望大家不要
推荐度:
导读react-router 路由切换动画的实现示例:路由切换动画 因为项目的需求,需要在路由切换的时候,加入一些比较 zb 的视觉效果,所以研究了一下。把这些学习的过程记录下来,以便以后回顾。同时也希望这些内容能够帮助一些跟我一样的菜鸟,让他们少走些坑。可能我对代码的表述不是很到位,希望大家不要


路由切换动画

因为项目的需求,需要在路由切换的时候,加入一些比较 zb 的视觉效果,所以研究了一下。把这些学习的过程记录下来,以便以后回顾。同时也希望这些内容能够帮助一些跟我一样的菜鸟,让他们少走些坑。可能我对代码的表述不是很到位,希望大家不要介意。机智的你们一定可以看明白。

参考内容:

  • react 路由动画
  • react-router Switch 组件
  • react 动画插件
  • 1.插件依赖

    使用的插件是react-transition-group。先简单介绍一下动画插件的使用方式。

    CSSTransition这个组件有两个比较主要的属性:key和in

    in:Boolean属性其实可以理解为是否显示当前内容节点。true则显示,false则不显示。

    key:String这个属性是配合TransitionGroup组件来使用的。在一般的列表组件中(列如 todolist),可以通过key来判断列表中的子节点需要被插入还是移除,然后触发动画。

    2. Switch 组件

    这个组件有一个很重要的属性:location。同时这个属性也是路由切换动画的关键所在。Switch组件的子组件(一般是 Route 和 Redirect)会根据当前浏览器的location作为匹配依据来进行路由匹配。但是如果Switch组件定义了location属性,其中的子组件就会以定义的location作为匹配依据。

    3.代码部分

    import React, { Component } from 'react'
    import { TransitionGroup, CSSTransition } from 'react-transition-group'
    import { Switch, Route, withRouter } from 'react-router-dom'
    
    @withRouter
    class Routes extends Component {
     render() {
     const location = this.props.location
     return (
     <TransitionGroup>
     <CSSTransition key={location.key} timeout={1000} classNames="fade">
     <Switch location={location}>
     <Route path="/route-1" component={Route1} />
     <Route path="/route-2" component={Route2} />
     </Switch>
     </CSSTransition>
     </TransitionGroup>
     )
     }
    }
    
    export default Routes

    4.原理分析

    先确定需求:当切换路由的时候,旧的路由内容在一定时间内过渡消失,新的路由内容过渡显示。

    在这个需要里面有两个重要的部分:

  • 过渡期间,会同时存在两个节点:新节点和旧节点
  • 旧节点应该显示旧的路由内容,新的节点应该显示新的路由内容
  • 4.1 同时存在两节点

    刚刚提到的CSSTransitionkey属性可以决定该节点是否需要显示。

    Router中的location属性会在路由发生变化的时候,进行更新,而location里面的key则可以作为CSSTransitionkey

    关于 history 对象,可以理解为一个数组,当页面的 location 发生变化时,或者刷新页面,history 就会push一个新的历史信息。在这个历史信息里面,有一个key属性,用来区分不同的历史记录(跳转新页面或者是刷新页面)

    当路由切换的时候,location对象就会改变,新的key会使得页面重新渲染时出现两个CSSTransition(新旧节点)。

    4.2 新旧节点对应新旧路由内容

    如果只是配置key属性,会发现旧的节点会去匹配新的路由内容。这是因为Route组件默认根据当前location进行匹配。为了让旧节点中的Route根据旧的location进行匹配,就需要设置Switchlocation属性。

    文档

    react-router 路由切换动画的实现示例

    react-router 路由切换动画的实现示例:路由切换动画 因为项目的需求,需要在路由切换的时候,加入一些比较 zb 的视觉效果,所以研究了一下。把这些学习的过程记录下来,以便以后回顾。同时也希望这些内容能够帮助一些跟我一样的菜鸟,让他们少走些坑。可能我对代码的表述不是很到位,希望大家不要
    推荐度:
    标签: 动画 效果 React
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top