欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue项目移动端滚动穿透问题的实现

程序员文章站 2022-04-09 16:12:57
概述今天在做 vue 移动端项目的时候遇到了滚动穿透问题,在网上查资料后,选取了我觉得最好的方法,记录下来供以后开发时参考,相信对其他人也有用。上层无需滚动如果上层无需滚动的话,直接屏蔽上层的 tou...

概述

今天在做 vue 移动端项目的时候遇到了滚动穿透问题,在网上查资料后,选取了我觉得最好的方法,记录下来供以后开发时参考,相信对其他人也有用。

上层无需滚动

如果上层无需滚动的话,直接屏蔽上层的 touchmove 事件即可。示例如下:

<div @touchmove.prevent>
我是里面的内容
</div>

上层需要滚动

如果上层需要滚动的话,那么固定的时候先获取 body 的滑动距离,然后用 fixed 固定,用 top 模拟滚动距离;不固定的时候用获取 top 的值,然后让 body 滚动到之前的地方即可。示例如下:

<template>
 <div @click="handlehambergerclick"></div>
</template>
<script>
export default {
 name: 'baseheadermobile',
 data() {
  return {
   isheadervisible: false,
  };
 },
 methods: {
  handlehambergerclick() {
   // hack: 滑动穿透问题
   if (!this.isheadervisible) {
    this.lockbody();
   } else {
    this.resetbody();
   }

   this.isheadervisible = !this.isheadervisible;
  },
  lockbody() {
   const { body } = document;
   const scrolltop = document.body.scrolltop || document.documentelement.scrolltop;
   body.style.position = 'fixed';
   body.style.width = '100%';
   body.style.top = `-${scrolltop}px`;
  },
  resetbody() {
   const { body } = document;
   const { top } = body.style;
   body.style.position = '';
   body.style.width = '';
   body.style.top = '';
   document.body.scrolltop = -parseint(top, 10);
   document.documentelement.scrolltop = -parseint(top, 10);
  },
 },
};
</script>

到此这篇关于vue项目移动端滚动穿透问题的实现的文章就介绍到这了,更多相关vue 移动端滚动穿透内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!