vue实现全屏滚动效果(非fullpage.js)

作者:coder-syl 时间:2024-05-28 15:46:00 

本文实例为大家分享了vue实现全屏滚动效果(的具体代码,供大家参考,具体内容如下

是什么

网页的一个页面占据一屏的宽高,多个页面上下或者左右拼接在一起。当滑动鼠标滚轮,或点击导航按钮时,可以平滑到对应的页面。

此次只实现鼠标滚动

实现原理

使用mousewheel , DOMMouseScroll(火狐用)监听鼠标滚动事件,当鼠标上下的滚动的时候,当前的页面transformY(屏高)或者transformX(屏宽)

代码实现

HTML


<template>
<div class="fullPage" ref="fullPage">
<div
 class="fullPageContainer"
 ref="fullPageContainer"
 @mousewheel="mouseWheelHandle" //监听鼠标事件
 @DOMMouseScroll="mouseWheelHandle" // 监听鼠标事件
>
 <div class="section section1">1</div>
 <div class="section section2">2</div>
 <div class="section section3">3</div>
 <div class="section section4">4</div>
</div>
</div>
</template>

JS


<script>
export default {
name: "Home",
data() {
return {
 fullpage: {
 current: 1, // 当前的页面编号
 isScrolling: false, // 是否在滚动,是为了防止滚动多页,需要通过一个变量来控制是否滚动
 deltaY: 0 // 返回鼠标滚轮的垂直滚动量,保存的鼠标滚动事件的deleteY,用来判断是往下还是往上滚
 }
};
},
methods: {
next() { // 往下切换
 let len = 4; // 页面的个数
 if (this.fullpage.current + 1 <= len) { // 如果当前页面编号+1 小于总个数,则可以执行向下滑动
 this.fullpage.current += 1; // 页面+1
 this.move(this.fullpage.current); // 执行切换
 }
},
pre() {// 往上切换
 if (this.fullpage.current - 1 > 0) { // 如果当前页面编号-1 大于0,则可以执行向下滑动
 this.fullpage.current -= 1;// 页面+1
 this.move(this.fullpage.current);// 执行切换
 }
},
move(index) {
 this.fullpage.isScrolling = true; // 为了防止滚动多页,需要通过一个变量来控制是否滚动
 this.directToMove(index); //执行滚动
 setTimeout(() => {  //这里的动画是1s执行完,使用setTimeout延迟1s后解锁
 this.fullpage.isScrolling = false;
 }, 1010);
},
directToMove(index) {
 let height = this.$refs["fullPage"].clientHeight; //获取屏幕的宽度
 let scrollPage = this.$refs["fullPageContainer"]; // 获取执行tarnsform的元素
 let scrollHeight; // 计算滚动的告诉,是往上滚还往下滚
 scrollHeight= -(index - 1) * height + "px";
 scrollPage.style.transform = `translateY(${scrollHeight})`;
 this.fullpage.current = index;
},
mouseWheelHandle(event) { // 监听鼠标监听
 // 添加冒泡阻止
 let evt = event || window.event;
 if (evt.stopPropagation) {
 evt.stopPropagation();
 } else {
 evt.returnValue = false;
 }
 if (this.fullpage.isScrolling) { // 判断是否可以滚动
 return false;
 }
 let e = event.originalEvent || event;
 this.fullpage.deltaY = e.deltaY || e.detail; // Firefox使用detail
 if (this.fullpage.deltaY > 0) {
 this.next();
 } else if (this.fullpage.deltaY < 0) {
 this.pre();
 }
}
}
};
</script>

CSS


<style scoped>
.fullPage{
height: 100%;//一定要设置,保证占满
overflow: hidden;//一定要设置,多余的先隐藏
background-color: rgb(189, 211, 186);
}
.fullPageContainer{
width: 100%;
height: 100%;
transition: all linear 0.5s;
}
.section {
width: 100%;
height: 100%;
background-position: center center;
background-repeat: no-repeat;
}
.section1 {
background-color: rgb(189, 211, 186);
background: url("./assets/intro-bg.jpg");
}
.section1 .secction1-content {
color: #fff;
text-align: center;
position: absolute;
top: 40%;
right: 0;
left: 0;
}
.secction1-content h1 {
font-size: 40px;
padding-bottom: 30px;
}
.secction1-content p {
font-size: 20px;
}
.section2 {
background-color: rgb(44, 48, 43);
}
.section3 {
background-color: rgb(116, 104, 109);
}
.section4 {
background-color: rgb(201, 202, 157);
}
</style>

来源:https://blog.csdn.net/shangyanaf/article/details/103079381

标签:vue,全屏滚动
0
投稿

猜你喜欢

  • Python制作微信好友背景墙教程(附完整代码)

    2022-11-13 08:31:08
  • Python设计模式中的结构型桥接模式

    2021-07-23 23:43:31
  • tensorflow+k-means聚类简单实现猫狗图像分类的方法

    2022-11-04 10:45:27
  • 使用 django orm 写 exists 条件过滤实例

    2022-01-20 02:42:48
  • Python反射用法实例简析

    2021-10-15 20:28:34
  • python 读写文件包含多种编码格式的解决方式

    2022-01-12 18:02:10
  • PHP错误Allowed memory size of 67108864 bytes exhausted的3种解决办法

    2024-03-15 18:25:42
  • PHP使用观察者模式处理异常信息的方法详解

    2023-10-19 15:53:30
  • Centos7下源码安装Python3 及shell 脚本自动安装Python3的教程

    2023-01-11 13:45:04
  • Python实现绘制多种激活函数曲线详解

    2022-06-30 01:02:06
  • python3定位并识别图片验证码实现自动登录功能

    2022-07-23 13:23:59
  • .NET中IoC框架Autofac用法讲解

    2024-06-05 09:26:21
  • JavaScript获取时区实现过程解析

    2023-08-22 20:58:34
  • 关于networkx返回图的邻接矩阵问题

    2021-04-09 13:10:35
  • Python新手学习标准库模块命名

    2021-01-16 05:18:06
  • Mysql简易索引方案讲解

    2024-01-20 15:08:11
  • Python开发毕设案例之桌面学生信息管理程序

    2021-03-02 14:56:08
  • 利用Django-environ如何区分不同环境

    2022-01-10 10:52:24
  • 15个设计得最糟糕最变态的CAPTCHA验证码

    2008-09-01 17:17:00
  • Python中的嵌套循环详情

    2022-10-29 05:53:54
  • asp之家 网络编程 m.aspxhome.com