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个技巧汇总

