当前位置: 首页 > news >正文

建设网站建设安全培训平台河北网站seo地址

建设网站建设安全培训平台,河北网站seo地址,地方门户网站的发展,做亚马逊网站一般发什么快递说明 vue路由切换时&#xff0c;当前页面左侧和右侧容器分别从两侧滑出&#xff0c;新页面左右分别从两侧滑入 效果展示 路由切换-滑入滑出效果 难点和踩坑 现路由和新路由始终存在一个页面根容器&#xff0c;通过<transition>组件&#xff0c;效果只能对页面根容器有效…

说明

vue路由切换时,当前页面左侧和右侧容器分别从两侧滑出,新页面左右分别从两侧滑入

效果展示

路由切换-滑入滑出效果

在这里插入图片描述

难点和踩坑

  1. 现路由和新路由始终存在一个页面根容器,通过<transition>组件,效果只能对页面根容器有效。
  2. 如果通过组件(页面)级路由守卫(进入、退出)来改变受控变量,模版对左右容器v-if + <transition>设置效果。
    • 路由切换是一瞬间的事,滑出动画来不及触发,路由就改变了
    • 所有页面都需要改造
    • 我确实没找到路由守卫进入事件 只有 import { onBeforeRouteLeave, onBeforeRouteUpdate } from 'vue-router'
  3. 如果纯通过onMounted和onUnMounted等钩子实现,和2的问题基本差不多

实现方式

基于<template>组件的钩子函数完全自主实现过渡效果.

钩子函数说明
beforeEnter在元素被插入到 DOM 之前被调用
enter在元素被插入到 DOM 之后的下一帧被调用
afterEnter当进入过渡完成时调用。
enterCancelled当进入过渡在完成之前被取消时调用
beforeLeave在 leave 钩子之前调用, 大多数时候,你应该只会用到 leave 钩子
leave在离开过渡开始时调用
afterLeave在离开过渡完成, 且元素已从 DOM 中移除时调用
leaveCancelled仅在 v-show 过渡中可用

直接上代码

<router-view> 改造

<router-view v-slot="{ Component }"><transitionmode="default":css="false"@before-leave="onBeforeLeave"@before-enter="onBeforeEnter"@enter="onEnter"@leave="onLeave"><component :is="Component"></component></transition>
</router-view>

钩子函数

/*** left-wrap和right-wrap 为路由页面中左右两侧模块*/// 退出前的钩子
const onBeforeLeave = (el: any) => {const left = el.querySelector('.left-wrap')const right = el.querySelector('.right-wrap')if (!left || !right) {return}left.style.transform = 'translateX(0)'right.style.transform = 'translateX(0)'
}
// 退出时的钩子
const onLeave = (el: any, done: Function) => {const left = el.querySelector('.left-wrap')const right = el.querySelector('.right-wrap')if (!left || !right) {done()return}left.style.transition = 'all 0.3s linear'right.style.transition = 'all 0.3s linear'left.style.transform = 'translateX(-120%)'right.style.transform = 'translateX(120%)'/*** 这里延迟done是为了过渡效果完成后再彻底退出* 如果将时长改大一点, 页面审查元素就能看到,* 路由切换时, 当前路由和新路由同时存在于页面, 当定时结束,done被调用时, 原路由组件才消失*/setTimeout(() => {done() // 完成过渡}, 300)
}// 进入前的钩子
const onBeforeEnter = (el: any) => {const left = el.querySelector('.left-wrap')const right = el.querySelector('.right-wrap')if (!left || !right) {return}left.style.transform = 'translateX(-120%)'right.style.transform = 'translateX(120%)'
}
// 进入时的钩子
const onEnter = (el: any, done: Function) => {const left = el.querySelector('.left-wrap')const right = el.querySelector('.right-wrap')if (!left || !right) {done()return}left.style.transition = 'all 0.5s linear'right.style.transition = 'all 0.5s linear'// 这里延时是为了等待原路由退出效果完成, 再为新路由组件设置进入效果setTimeout(() => {left.style.transform = 'translateX(0)'right.style.transform = 'translateX(0)'done() // 完成过渡}, 300)
}

总计

  • 多调整参数看效果,就能大概猜出transition组件的实现原理
  • 通过钩子函数自定义过渡或动画效果,可操作性确实大,就是有点麻烦
http://www.yidumall.com/news/87655.html

相关文章:

  • 海外如何淘宝网站建设最知名的网站推广公司
  • 重庆有哪些做网站的公司湖南专业seo优化
  • 甜点网站要怎么做小说百度风云榜
  • 芜湖先锋网站两学一做如何在百度发布文章
  • 怎么用手机搭建网站百度关键词价格排行榜
  • 公司网站 用 个人备案域名电商网站上信息资源的特点包括
  • 东圃做网站公司培训体系搭建
  • 不申请域名可以 做网站吗郑州seo招聘
  • 专业的句容网站建设seo谷歌
  • wordpress自己设计优化大师手机版下载
  • 网站开发是web开发吗windows优化大师会员兑换码
  • 南京做网站yuanmus百度商城官网
  • 电商网站建设重要性业务网站制作
  • 制作好的网页模板如何放入网站cms中宽带营销策略
  • 做微商都去哪些网站留言网站优化方式有哪些
  • 用eclipse做网站模板培训网络营销的机构
  • 石材外贸在哪个网站做今日头条郑州头条新闻
  • 网站建设一般多少钱新闻谷歌seo排名优化服务
  • 做付费软件网站怎么做绍兴seo公司
  • 鞍山市城市建设管理局网站南宁网络推广软件
  • 佛山新网站建设怎么样中国推广网
  • 做电商网站需要会些什么营销技巧在线完整免费观看
  • 网站开发的选题意义及背景设计公司企业网站
  • 海外仓一件代发平台福州百度推广排名优化
  • 免费招聘网站都有哪些爱站网关键词搜索工具
  • 西安火车站网站建设福州百度关键词优化
  • 阿里云 域名 做网站微信怎么引流营销呢
  • 沧州做网站价格快速排名网站
  • 程序员做的导航网站国际军事新闻
  • 免费领取手机网站小白如何学电商运营