Vue.js实现微信过渡动画左右切换效果

发布时间 - 2026-01-11 01:51:11    点击率:

前言

在awesomes上寻找移动端框架的时候意外发现了vux的页面切换效果,后面由于其他考虑没有选用vuex但是这个切换效果确实感觉很有新意,也就看了下源码,这里贴一份备用。

需要用到的技术栈:Vue+Vuex

先看看效果图


过渡动画

示例代码

//app.vue
<transition :name="'vux-pop-' + (direction === 'forward' ? 'in' : 'out')">
 <keep-alive>
 <router-view class="router-view" ></router-view>
 </keep-alive>
</transition>
<script>
 import { mapState } from 'vuex'
 import sideFooter from "./components/Footer.vue"

 export default {
 name: 'app',
 data () {
 return {
 showFooter : false
 }
 },
 components : {
 sideFooter
 },
 computed:{
 ...mapState({
 direction: state => state.mutations.direction
 })
 },
 }
</script>

<style scoped>
 .vux-pop-out-enter-active,
 .vux-pop-out-leave-active,
 .vux-pop-in-enter-active,
 .vux-pop-in-leave-active {
 will-change: transform;
 transition: all 250ms;
 height: 100%;
 top: 0;
 position: absolute;
 backface-visibility: hidden;
 perspective: 1000;
 }

 .vux-pop-out-enter {
 opacity: 0;
 transform: translate3d(-100%, 0, 0);
 }

 .vux-pop-out-leave-active {
 opacity: 0;
 transform: translate3d(100%, 0, 0);
 }

 .vux-pop-in-enter {
 opacity: 0;
 transform: translate3d(100%, 0, 0);
 }

 .vux-pop-in-leave-active {
 opacity: 0;
 transform: translate3d(-100%, 0, 0);
 }
</style>
// main.js
const history = window.sessionStorage;
history.clear()
let historyCount = history.getItem('count') * 1 || 0;
history.setItem('/', 0);

router.beforeEach(function (to, from, next) {

 const toIndex = history.getItem(to.path);
 const fromIndex = history.getItem(from.path);

 if (toIndex) {
 if (!fromIndex || parseInt(toIndex, 10) > parseInt(fromIndex, 10) || (toIndex === '0' && fromIndex === '0')) {
 store.commit('UPDATE_DIRECTION', {direction: 'forward'})
 } else {
 store.commit('UPDATE_DIRECTION', {direction: 'reverse'})
 }
 } else {
 ++historyCount;
 history.setItem('count', historyCount);
 to.path !== '/' && history.setItem(to.path, historyCount);
 store.commit('UPDATE_DIRECTION', {direction: 'forward'})
 }
 next()
});

这里还用到了vuex,但是我stroe写了很多就不提出来了,主要就是通过 UPDATE_DIRECTION方法更新每一次的路由方向是前进还是后退。

man.js里面主要思想就是给路由增加一个索引存到sessionStorage里面,以点击过的索引值不变,新增加的路由,索引增加1,同时count+1,这样在页面切换时通过比较索引值的大小,大的向右小的向左,做到左右有规律的过渡。

好了至此一个左右切换的过渡效果就成了,最近由于一直在开发也没怎么更新文章,如果有朋友有好的想法欢迎与我交流。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如有疑问大家可以留言交流,谢谢大家对的支持。


# vue  # 过渡动画  # 过渡动画案例  # vue2.0  # Vue列表如何实现滚动到指定位置样式改变效果  # Vue.js 无限滚动列表性能优化方案  # vue实现歌手列表字母排序下拉滚动条侧栏排序实时更新  # vue通过滚动行为实现从列表到详情  # 返回列表原位置的方法  # Vue2.0 实现歌手列表滚动及右侧快速入口功能  # Vuejs第七篇之Vuejs过渡动画案例全面解析  # Vue.js每天必学之过渡与动画  # Vue 过渡实现轮播图效果  # 关于vue状态过渡transition不起作用的原因解决  # vue实现列表滚动的过渡动画  # 来了  # 好了  # 看了  # 也就  # 也没  # 就不  # 如有  # 很有  # 与我  # 写了  # 这篇文章  # 谢谢大家  # 还用  # 发现了  # 但是我  # 就成了  # router  # view  # import  # script 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  如何在企业微信快速生成手机电脑官网?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  Laravel如何为API生成Swagger或OpenAPI文档  javascript基本数据类型及类型检测常用方法小结  Python制作简易注册登录系统  Python函数文档自动校验_规范解析【教程】  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  Laravel如何实现事件和监听器?(Event & Listener实战)  JavaScript如何实现路由_前端路由原理是什么  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  如何在Windows服务器上快速搭建网站?  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别  Swift中swift中的switch 语句  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  Python3.6正式版新特性预览  如何在 React 中条件性地遍历数组并渲染元素  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  如何在腾讯云免费申请建站?  如何在万网利用已有域名快速建站?  Internet Explorer官网直接进入 IE浏览器在线体验版网址  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  油猴 教程,油猴搜脚本为什么会网页无法显示?  如何在橙子建站中快速调整背景颜色?  零基础网站服务器架设实战:轻量应用与域名解析配置指南  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  js实现获取鼠标当前的位置  如何在橙子建站上传落地页?操作指南详解  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】  Laravel如何升级到最新版本?(升级指南和步骤)  如何快速搭建支持数据库操作的智能建站平台?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  济南网站建设制作公司,室内设计网站一般都有哪些功能?  长沙做网站要多少钱,长沙国安网络怎么样?  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  MySQL查询结果复制到新表的方法(更新、插入)  如何确认建站备案号应放置的具体位置?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  jQuery中的100个技巧汇总