摘要:本文将带你了解WEBAPP开发之vue实现webapp页面切换动画,希望本文对大家学WebApp有所帮助。
vue-router实现webApp切换效果
运行方法
#安装依赖
npminstall
#浏览器打开localhost:8080
npmrundev
快速集成
1.复制PageTransittion.vue到项目目录。
2.修改router配置。
Router.prototype.goBack=function(){
this.isBack=true
window.history.go(-1)
}
constrouter=newRouter({
routes:[
{
path:'/',
name:'PageTransition',
component:PageTransition,//引入页面切换组件
children:[{
path:'',
component:Index//父路由访问页面,例如,访问www.aaa.com/显示的是Index组件
},{
path:'/pageA',
component:PageA//子路由组件例如,访问www.aaa.com/pageA显示为PageA
},{
path:'/pageB',
component:PageB//子路由组件例如,访问www.aaa.com/pageB显示为PageB
}]
}
]
})
方案实现
记录页面状态
要实现页面前进后台动画,首先必须知道页面状态(即是页面是进入下一页,还是后退),我们可以通过改写router.go方法记录回退状态,页面如果需要回退时,调用
$router.go(-1)
修改router/index.vue
//增强原方法,好处是旧的业务模块不需要任何变动
Router.prototype.go=function(){
this.isBack=true
window.history.go(-1)
}
//或者你可以新建一个方法
Router.prototype.goBack=function(){
this.isBack=true
this.go(-1)
}
当newRouter时,实例就包含go/goBack方法。
监听路由变化
使用嵌套路由的方式引入子页面,监听根路由的update钩子做相应操作。
beforeRouteUpdate(to,from,next){
//如果isBack为true时,证明是用户点击了回退,执行slide-right动画
letisBack=this.$router.isBack
if(isBack){
this.transitionName='slide-right'
}else{
this.transitionName='slide-left'
}
//做完回退动画后,要设置成前进动画,否则下次打开页面动画将还是回退
this.$router.isBack=false
next()
}
动画效果
通过transition执行动画
css代码
.child-view{
position:absolute;
width:100%;
transition:all.8scubic-bezier(.55,0,.1,1);
}
.slide-left-enter,.slide-right-leave-active{
opacity:0;
-webkit-transform:translate(50px,0);
transform:translate(50px,0);
}
.slide-left-leave-active,.slide-right-enter{
opacity:0;
-webkit-transform:translate(-50px,0);
transform:translate(-50px,0);
}
路由设置
router/index.js
constrouter=newRouter({
routes:[
{
path:'/',
name:'PageTransition',
component:PageTransition,
children:[{
//该路由为父路由的默认路由
path:'',
component:Index
},{
path:'/pageA',
component:PageA
},{
path:'/pageB',
component:PageB
}]
}
]
})
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之WebApp频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号