vue原生满屏滚动方式

 更新时间:2024年08月28日 09:00:29   作者:zyy_wx  
这篇文章主要介绍了vue原生满屏滚动方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

vue原生满屏滚动

vue原生满屏滚动效果,点击左侧导航栏可滚动至对应屏幕。

效果图

代码

<template>
  <div class='page-sum'>
    <div class='distance'>
      <!--      左侧导航栏-->
      <div class='page-nav'>
        <div>
          <div @click='scrollByIndex(0)' class='nav-type'>
            <p :style="navIndex===0?'color:#00D2C7':''">企业主页</p>
          </div>
          <div @click='scrollByIndex(4)' class='nav-type'>
            <p :style="navIndex===1?'color:#00D2C7':''">案例中心</p>
          </div>
          <div @click='scrollByIndex(5)' class='nav-type'>
            <p :style="navIndex===2?'color:#00D2C7':''">方案中心</p>
          </div>
          <div @click='scrollByIndex(7)' class='nav-type'>
            <p :style="navIndex===3?'color:#00D2C7':''">咨讯库</p>
          </div>
          <div @click='scrollByIndex(9)' class='nav-type'>
            <p :style="navIndex===4?'color:#00D2C7':''">文档库</p>
          </div>
        </div>
      </div>
      <div class='page-box'>
        <div class='page-one' style='background: #5daf34'>
          第一页
        </div>
        <div class='page-two' style='background: #1b8bff'>
          第二页
        </div>
 
        <div class='page-three' style='background: #00a2d4'>
          第三页11
        </div>
        <div class='page-four' style='background: #fab6b6'>
          第三页22
        </div>
 
        <div class='page-five' style='background: #00DECB'>
          第四页
        </div>
 
        <div class='page-six' style='background: #00D2C7'>
          第五页11
        </div>
 
        <div class='page-seven' style='background: #2D64B3'>
          第五页22
        </div>
        <div class='page-eight' style='background: #fab6b6'>
          第六页11
        </div>
 
        <div class='page-nine' style='background: #00DECB'>
          第六页22
        </div>
 
        <div class='page-ten' style='background: #00b7ee'>
          第七页
        </div>
 
      </div>
    </div>
  </div>
</template>
<script>
 
export default {
  name: 'index',
  data() {
    return {
      navIndex: 0,
      wheel: 0,
      style: ''
    }
  },
  mounted() {
    this.initWheel()  //整屏移动
  },
  watch: {
    wheel: {
      handler(val) {
      }
    }
  },
  methods: {
    initWheel() {
      this.wheel = 0   //  0 到 10
      let timer = 1500
      let agent = navigator.userAgent.toLowerCase()
      let isMac = /macintosh|mac os x/i.test(navigator.userAgent)
      if (agent.indexOf('win32') >= 0 || agent.indexOf('wow32') >= 0 || agent.indexOf('win64') >= 0 || agent.indexOf('wow64') >= 0) {
        timer = 1000
      }
      if (isMac) {
        timer = 1500
      }
      window.addEventListener('wheel', this.throttle(this.wheelHandler, timer))  //兼容mac的方法  1500  timer  windows  为1000  mac为1500
    },
    throttle(func, delay) {
      let prev = Date.now()
      return function() {
        let context = this
        let args = arguments
        let now = Date.now()
        if (now - prev >= delay) {
          func.apply(context, args)
          prev = Date.now()
        }
      }
    },
    wheelHandler(e) {
      let main = document.querySelector('.page-box')
      let headHeight = document.querySelector('.page-one').clientHeight
      if (e.deltaY > 0) {
        if (this.wheel === 9) return
        this.wheel++
      } else {
        if (this.wheel === 0) return
        this.wheel--
      }
      if (this.wheel === 0) {
        main.style.transform = `translateY(0)` //整屏上下移
      } else {
        main.style.transform = `translateY(calc(-${headHeight}px - ${(this.wheel - 1) * 100}vh)` //整屏上下移
      }
 
      // 划分左侧导航栏内有几屏
      if (this.wheel >= 0 && this.wheel < 4) { // 0 4 6 8
        this.navIndex = 0
      } else if (this.wheel >= 4 && this.wheel < 5) {
        this.navIndex = 1
      } else if (this.wheel >= 5 && this.wheel < 7) {
        this.navIndex = 2
      } else if (this.wheel < 9) {
        this.navIndex = 3
      } else if (this.wheel === 9) {
        this.navIndex = 4
      }
    },
    scrollByIndex(index) {
      let e = {
        deltaY: 100
      }
      this.wheel = index - 1
      this.wheelHandler(e)
    }
  }
}
</script>
 
<style lang='scss' scoped>
.page-sum {
  width: 100%;
  height: 100vh;
  overflow: hidden;
  position: relative;
}
 
.distance {
  width: 75rem;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
 
.page-box {
  width: 65.625rem;
  transform: translateY(0);
  transition: 1s;
}
 
.page-one {
  height: 100vh;
  position: relative;
  overflow: hidden;
}
 
.page-two {
  height: 100vh;
}
 
.page-three, .page-four {
  height: 100vh;
}
 
.page-five {
  height: 100vh;
}
 
.page-six {
  height: 100vh;
}
 
.page-seven {
  height: 100vh;
}
 
.page-eight {
  background: #fff;
  height: 100vh;
}
 
.page-nine {
  width: 100%;
  height: 100vh;
}
 
.page-ten {
  height: 100vh;
}
 
.page-nav {
  transform: translateY(50%);
  width: 8rem;
  height: 22rem;
  text-align: center;
  border-radius: 0.125rem;
  background: #FFF;
  box-shadow: 2px 1px 8px 1px rgba(208, 208, 208, 0.16);
}
 
.nav-type {
  cursor: pointer;
  font-size: 1rem;
  font-weight: 400;
  line-height: 3rem;
  color: #323232;
}
 
//滚动条的宽度
::-webkit-scrollbar {
  width: 0.25rem;
  height: 0.25rem;
 
}
 
//滚动条的设置
::-webkit-scrollbar-thumb {
  background-color: #ddd;
  background-clip: padding-box;
  min-height: 1.75rem;
}
</style>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 一个例子轻松学会Vue.js

    一个例子轻松学会Vue.js

    这篇文章主要为大家详细介绍了一个例子,帮助大轻松学会Vue.js,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • 详解Vue中的基本语法和常用指令

    详解Vue中的基本语法和常用指令

    Vue.js 是一套构建用户界面的框架,**只关注视图层**,它不仅易于上手,还便于与第三方库或既有项目整合。这篇文章主要介绍了vue 的基本语法和常用指令,需要的朋友可以参考下
    2019-07-07
  • 一文彻底搞懂Vue的MVVM响应式原理

    一文彻底搞懂Vue的MVVM响应式原理

    这篇文章主要介绍了一文彻底搞懂Vue的MVVM响应式原理,vue则是采用发布者-订阅者模式,通过Object.defineProperty()来劫持各个属性的getter和setter,在数据变动时发布消息给订阅者,触发相应的监听回调
    2022-06-06
  • Element实现表格分页数据选择+全选所有完善批量操作

    Element实现表格分页数据选择+全选所有完善批量操作

    这篇文章主要介绍了Element实现表格分页数据选择+全选所有完善批量操作,文中通过示例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • vue中计算属性computed理解说明包括vue侦听器,缓存与computed的区别

    vue中计算属性computed理解说明包括vue侦听器,缓存与computed的区别

    这篇文章主要介绍了对vue中计算属性computed理解说明包括vue侦听器,缓存与computed的区别,需要的朋友可以参考下
    2022-05-05
  • Vue自定义指令深入探讨实现

    Vue自定义指令深入探讨实现

    这篇文章主要介绍了Vue自定义指令的实现,Vue支持自定义指令,开发者可以根据自己的需求,创建自己的指令来扩展Vue的功能,需要详细了解可以参考下文
    2023-05-05
  • 在Vue3中创建和使用自定义指令的实现方式

    在Vue3中创建和使用自定义指令的实现方式

    在现代前端开发中,Vue.js 是一个非常流行的框架,它提供了许多强大的功能来帮助开发者构建高效的用户界面,自定义指令是 Vue.js 的一个重要特性,它允许开发者扩展 HTML 元素的功能,本文将详细介绍如何在 Vue3 中创建和使用自定义指令,并提供示例代码来帮助理解
    2024-12-12
  • Vue精美简洁登录页完整代码实例

    Vue精美简洁登录页完整代码实例

    这篇文章主要给大家介绍了关于Vue精美简洁登录页完整代码的相关资料,通过文中的方法大家可以使用实现简单的用户登录界面,下面通过示例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • 使用canvas实现一个vue弹幕组件功能

    使用canvas实现一个vue弹幕组件功能

    这篇文章主要介绍了使用canvas实现一个vue弹幕组件功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • Vue+Canvas绘图使用的讲解

    Vue+Canvas绘图使用的讲解

    这篇文章主要介绍了Vue+Canvas绘图的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论