vue-router路由动画左滑右滑效果实现

这里用到路由的钩子函数,组件路由 beforeRouteUpdate。

一个页面是有二级导航的,在切换二级导航的时候,对应的内容是在变化的;这个页面是复用的,只会生成一次,切换二级导航的时,如何知道导航在更新呢?

  一个页面有二级导航的时候,点击二级导航的时候导航路径更新了,会触发路由钩子函数beforeRouteUpdate。

Vue模板中的应用:

name是定义的过渡动画的名称

  <keep-alive>
      <transition :name="transitionName">
        <router-view/>
      </transition>
    </keep-alive>

 mounted中定义组件路由钩子函数beforeRouteUpdate:

  beforeRouteUpdate(to, from, next) {
    const tp = to.path;
    const fp = from.path;

    let leftPaths = [
      `fp === "/edit" && tp === "/edit/rename"`,
      `fp === "/edit" && tp === "/edit/interest"`
    ];
    let rightPaths = [
      `fp === "/edit/rename" && tp === "/edit"`,
      `fp === "/edit/interest" && tp === "/edit"`
    ];

    this.leftSlide(leftPaths, fp, tp);
    this.rightSlide(rightPaths, fp, tp);

    setTimeout(() => {
      next()
    }, 50)
  },

 

methods里定义的方法:

    leftSlide(paths, fp, tp) {
      paths.forEach(path => {
        if (eval(path)) {
          this.transitionName = 'slide-left';
        }
      })
    },
    rightSlide(paths, fp, tp) {
      paths.forEach(path => {
        if (eval(path)) {
          this.transitionName = 'slide-right';
        }
      })
    },

定义全局的class类:

.slide-left-enter {
  transform: translateX(100%);
}
.slide-left-enter-active{
  transition: transform .3s;
}
.slide-left-enter-to{
  transform: translateX(0);
}
.slide-left-leave {
  transform: translateX(0);
}
.slide-left-leave-active {
  transition: transform .3s
}
.slide-left-leave-to {
  transform: translateX(0);
}

.slide-right-enter {
  transform: translateX(0);
}
.slide-right-enter-active{
  transition: transform .3s;
}
.slide-right-enter-to{
  transform: translateX(0);
}
.slide-right-leave {
  transform: translateX(0);
}
.slide-right-leave-active {
  transition: transform .3s;
}
.slide-right-leave-to {
  transform: translateX(100%);
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue-router路由模式有三种:哈希模式(hash mode)、历史模式(history mode)和抽象模式(abstract mode)。 1. 哈希模式:默认使用的路由模式,通过改变URL中的hash值来进行路由的切换。例如:http://example.com/#/home。 实现方式:通过监听URL中hash值变化的事件,当hash值改变时,动态渲染相应的组件内容。 原理:浏览器会将hash值的变化当作页面的锚点变化来处理,不会重新发送请求,而是通过监听hashchange事件来更新URL对应的视图。 2. 历史模式:通过修改URL的路径来进行路由的切换,去除URL中的hash值。例如:http://example.com/home。 实现方式:通过HTML5的history API(pushState和replaceState方法)来修改URL路径并将路由信息保存在浏览器的history栈中。同时需要配合服务器端的配置,将所有的URL请求都指向根页面。 原理:history API可以修改URL路径并保持在浏览器的历史记录中,当URL发生改变时,浏览器会发送请求到服务器,服务器通过配置将所有的URL请求都指向根页面,然后由vue-router解析路由信息并呈现对应的视图。 3. 抽象模式:不依赖于浏览器的URL,可以将路由信息保存在任意位置,并通过切换路由信息来改变页面内容。 实现方式:通过自定义路由器(Router)和路由(Route)对象来管理路由状态,并通过编程方式来切换路由信息。 原理:抽象模式不依赖于浏览器的URL,可以将路由信息保存在任意位置,例如内存或者状态管理库中。通过切换路由信息,可以触发相应的组件渲染。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值