vue实现页面切换滑动效果


Posted in Javascript onJune 29, 2020

本文实例为大家分享了vue实现页面切换滑动的具体代码,供大家参考,具体内容如下

试着用Vue做了个页面切换时滑动的效果,如下示例,源码

vue实现页面切换滑动效果

这里使用了Vue的transition组件,具体可见文档

直接看实现过程

先在本机安装vue-cli

npm install -g @vue/cli

初始化一个项目

vue create hello-world

创建完毕后安装vue-router和vuex,现在vue-cli3支持图形化界面,可以直接在项目目录用ui启动,在管理页面点击安装

vue ui

然后建立这样一个项目结构

vue实现页面切换滑动效果

store.js

首先在vuex的仓库里存储页面切换的状态

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
 state: {
 states: 'turn-left'
 },
 mutations: {
 setTransition(state, states) {
 state.states = states
 }
 },
 actions: {

 }
})

建立四个切换用的页面

A,B,C,D换个颜色就行,记得在router.js里配置下路由,有问题可以去我的仓库看源码。

<template>
 <div class="A">
 <top title="a"></top>
 <bottom bg="red"></bottom>
 </div>
</template>

<script>
 import top from "../components/top.vue";
 import bottom from "../components/bottom.vue";
 export default {
 data() {
 return {};
 },
 components: {
 top,
 bottom
 }
 };
</script>

<style scoped>
 .A {
 width: 100%;
 height: 100%;
 background-color: blue;
 position: fixed;
 }

</style>

顶部标题和底部颜色都通过props传给子组件

top.vue

<template>
 <div class="header">
 <div class="left" @click="back">
 back
 </div>
 <div class="center">
 {{title}}
 </div>
 </div>
</template>

<script>
 export default {
 data() {
 return {};
 },
 props: ["title"],
 methods: {
 back() {
 this.$store.commit("setTransition", "turn-right");
 this.$router.back(-1);
 }
 }
 };
</script>

<style scoped>
 .header {
 position: fixed;
 width: 100%;
 height: 40px;
 line-height: 40px;
 background-color: rgb(100, 231, 60);
 }
 .clearfix {
 overflow: auto;
 }
 .left {
 position: fixed;
 left: 0;
 width: 60px;
 }
 .center {
 left: 50%;
 position: fixed;
 }
</style>

bottom.vue

<template>
 <div class="bottom" :style="'top:'+ num + 'px;background-color: '+ bg + ';'">
 bottom
 </div>
</template>

<script>
 export default {
 name: "bottom",
 data() {
 return {
 num:0,
 test:1,
 };
 },
 props: ["bg"],
 mounted() {
 let screenH = document.documentElement.clientHeight || window.innerHeight;
 window.console.log(screenH);
 this.num = screenH - 50 - 50;
 }
 }
</script>

<style scoped>
 .bottom {
 width: 100%;
 height: 50px;
 line-height: 50px;
 position: absolute;
 }
</style>

过程中遇到的问题

原本底部是使用fixed定位的,但fixed在transition的动画中会出现一些奇怪的抖动,原因不明,有大佬知道的话希望能留言告知下。

这里使用absolute替代了fixed,进页面时获取页面高度,然后计算出top值。

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于JavaScript中var声明变量作用域的推断
Dec 16 Javascript
JS定义回车事件(实现代码)
Jul 08 Javascript
jquery插件lazyload.js延迟加载图片的使用方法
Feb 19 Javascript
基于javascript实现句子翻牌网页版小游戏
Mar 23 Javascript
AngularJS实现在ng-Options加上index的解决方法
Nov 03 Javascript
JS封装通过className获取元素的函数示例
Dec 20 Javascript
详解微信小程序 通过控制CSS实现view隐藏与显示
May 24 Javascript
es6在react中的应用代码解析
Nov 08 Javascript
JS实现生成由字母与数字组合的随机字符串功能详解
May 25 Javascript
element-ui upload组件多文件上传的示例代码
Oct 17 Javascript
AutoJs实现刷宝短视频的思路详解
May 22 Javascript
js绘制一条直线并旋转45度
Aug 21 Javascript
微信小程序实现导航栏和内容上下联动功能代码
Jun 29 #Javascript
Vue.js中Line第三方登录api的实现代码
Jun 29 #Javascript
vue实现列表滚动的过渡动画
Jun 29 #Javascript
element跨分页操作选择详解
Jun 29 #Javascript
vue实现数字滚动效果
Jun 29 #Javascript
js实现从右往左匀速显示图片(无缝轮播)
Jun 29 #Javascript
Vue实现可移动水平时间轴
Jun 29 #Javascript
You might like
PHP clearstatcache()函数详解
2010/03/02 PHP
php中处理mysql_fetch_assoc返回来的数组 不用foreach----echo
2011/05/04 PHP
基于PHP导出Excel的小经验 完美解决乱码问题
2013/06/10 PHP
Yii数据模型中rules类验证器用法分析
2016/07/15 PHP
Cookie跨域问题解决方案代码示例
2020/11/24 PHP
JS面向对象、prototype、call()、apply()
2009/05/14 Javascript
jQuery 选择器理解
2010/03/16 Javascript
js中通过split函数分割字符串成数组小例子
2013/09/21 Javascript
jquery属性选择器not has怎么写 行悬停高亮显示
2013/11/13 Javascript
javascript快速排序算法详解
2014/09/17 Javascript
TypeError document.getElementById(...) is null错误原因
2015/05/18 Javascript
JavaScript中0和&quot;&quot;比较引发的问题
2016/05/26 Javascript
jQuery+正则+文本框只能输入数字的实现方法
2016/10/07 Javascript
微信公众号  提示:Unauthorized API function 问题解决方法
2016/12/05 Javascript
JS异步文件分片断点上传的实现思路
2016/12/25 Javascript
深入理解Nodejs Global 模块
2017/06/03 NodeJs
利用jQuery异步上传文件的插件用法详解
2017/07/19 jQuery
javascript将url解析为json格式的两种方法
2017/08/18 Javascript
初探js和简单隐藏效果的实例
2017/11/23 Javascript
详解Vue的钩子函数(路由导航守卫、keep-alive、生命周期钩子)
2018/07/24 Javascript
Vue项目总结之webpack常规打包优化方案
2019/06/06 Javascript
vue element 生成无线级左侧菜单的实现代码
2019/08/21 Javascript
微信小程序表单验证WxValidate的使用
2019/11/27 Javascript
[54:25]Ti4 循环赛第三日LGD vs MOUZ
2014/07/12 DOTA
Python实现端口复用实例代码
2014/07/03 Python
讲解Python中运算符使用时的优先级
2015/05/14 Python
Python3.5编程实现修改IIS WEB.CONFIG的方法示例
2017/08/18 Python
有关Python的22个编程技巧
2018/08/29 Python
如何实现Django Rest framework版本控制
2019/07/25 Python
python脚本监控logstash进程并邮件告警实例
2020/04/28 Python
机关党员公开承诺书
2014/08/30 职场文书
个人授权委托书范本格式
2014/10/12 职场文书
公务员检讨书
2014/11/01 职场文书
工作迟到检讨书范文
2015/05/06 职场文书
军训新闻稿范文
2015/07/17 职场文书
对Keras自带Loss Function的深入研究
2021/05/25 Python