WEBAPP开发之vue实现webapp页面切换动画
白羽 2018-07-19 来源 :网络 阅读 1119 评论 0

摘要:本文将带你了解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频道!

本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程