vue实现楼层跳转效果

本文实例为大家分享了vue实现楼层跳转效果的具体代码,供大家参考,具体内容如下

实现效果:当翻滚页面时,对应的选项卡也会进行相应的变化,点击选项卡也会直接跳转到对应的位置

先是获取对应的dom元素,然后再监听滚动事件,判断符合条件的元素,进行改变对应的楼层选项卡位置。

jump方法则是通过点击直接跳转到对应的位置。

整个页面代码如下:

<template>
  <div>
      <h1>这是楼层测试的页面</h1>
      <!-- 这是流程的目录 -->
      <div class="totalM">
          <div class="menu" @click="jump(0)" :class="[num==0?'sele':'']">1</div>
          <div class="menu" @click="jump(1)" :class="[num==1?'sele':'']">2</div>
          <div class="menu" @click="jump(2)" :class="[num==2?'sele':'']">3</div>
          <div class="menu" @click="jump(3)" :class="[num==3?'sele':'']">4</div>
          <div class="menu" @click="jump(4)" :class="[num==4?'sele':'']">5</div>
      </div>
      <!-- 这是楼层的内容 -->
      <div>
        <div class="h-800" style="background:red;"><h1>1</h1></div>
        <div class="h-800" style="background:yellow;"><h1>2</h1></div>
        <div class="h-800" style="background:blue;"><h1>3</h1></div>
        <div class="h-800" style="background:black;"><h1>4</h1></div>
        <div class="h-800" style="background:pink;"><h1>5</h1></div>
      </div>
  </div>
</template>

<script>
export default {
    data() {
        return {
            num:0,
        }
    },
    created() {
        var that=this
        var inner = document.getElementsByClassName('h-800');
            // 注册滚动监听事件
            window.onscroll = function() {
                // 获取滚动条距离页面底部的距离
                var tops = document.documentElement.scrollTop || document.body.scrollTop;
                // console.log(tops)
                //判断滚动的位置,从而改变楼层选项的样式
                for(var i = 0; i < inner.length; i++) {
                    if(inner[i].offsetTop <= tops+200 && tops<=inner[i].offsetTop) {
                        that.num=i
                    }
                }
            }

    },
    methods: {
        // 楼层跳转的方法index
        jump(index){
            this.num=index
            var body = document.getElementsByTagName('body')[0];
              // 获取所有的楼层
            var inner = document.getElementsByClassName('h-800');
            console.log(body)
            console.log(inner)
            console.log(index)
            console.log(inner[index].offsetTop)
            window.scrollTo(0,inner[index].offsetTop)
            // document.body.scrollTop=inner[index].offsetTop
            console.log(body.scrollTop)
        }
    },

}
</script>

<style scoped>
.h-800{
    width: 100%;
    height: 500px;
}
.totalM{
    position: fixed;
    width:100px;
    background:gray;
    right:100px;
    bottom:100px;
}
.menu{
    /* margin-bottom:10px; */
}
.sele{
    background:white;
}
</style>

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

(0)

相关推荐

  • vue-router跳转页面的方法

    使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生 官方文档请点击这里 ## vue-router 第一步当然是安装了,用npm安装命令 npm install vue-router --save-dev 第二步在.vue组件里添加标签,格式如下 <div id="app"> <p> <!-- 使用 router-link 组件来导航. --> <

  • vue-router跳转时打开新页面的两种方法

    最近还是在痛苦的挣扎中 挣扎吧 记录一下在vue项目中如何实现跳转到一个新页面(一个比较简单又比较基础的问题了),有两个方法: 1.<vue-link>标签实现新窗口打开 官方文档中说 v-link 指令被 <router-link> 组件指令替代,且 <router-link> 不支持 target="_blank" 属性,如果需要打开一个新窗口必须要用<a>标签,但事实上vue2版本的 <router-link> 是支持

  • Vue.js实战之利用vue-router实现跳转页面

    前言 使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生. 官方文档: https://router.vuejs.org/zh-cn/essentials/getting-started.html 这次的实例主要实现下图的效果: 项目结构: 一.配置 Router 用 vue-cli 创建的初始模板里面,并没有 vue-router,需要通过 npm 安装 cnpm i vue-router -D

  • VueJs路由跳转——vue-router的使用详解

    对于单页应用,官方提供了vue-router进行路由跳转的处理,本篇主要也是基于其官方文档写作而成. 安装 基于传统,我更喜欢采用npm包的形式进行安装. npm install vue-router --save 当然,官方采用了多种方式进行安装,包括bower,cdn等. 基本用法 在HTML文档中使用,只需要利用v-link这个directive就行了,如: <a v-link="{path: '/view-a'}">Go to view-a</a> ​p

  • vue跳转页面的几种方法(推荐)

    vue跳转不同页面的多种方法 1:router-link跳转 <!-- 直接跳转 --> <router-link to='/testDemo'> <button>点击跳转2</button> </router-link> <!-- 带参数跳转 --> <router-link :to="{path:'testDemo',query:{setid:123456}}"> <button>点击跳

  • Vue-Router来实现组件间跳转的三种方法

    通过VueRouter来实现组件之间的跳转,供大家参考,具体内容如下 提供了3种方式实现跳转: ①直接修改地址栏中的路由地址 <!doctype html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="js/vue.js"></script> <!-- 引入文件 --> &

  • vue实现未登录跳转到登录页面的方法

    环境:vue 2.9.3; webpack;vue-router 目的:实现未登录跳转 例子:直接在url地址栏输入...../home,但是这个页面要求需要登陆之后才能进入,判断的值就通过登陆之后给本地缓存存入的token判断,如果没有就跳转到登录页面,有的话就打开. 图示: 1.直接在url地址栏输入http://127.0.0.1:9000/#/home,但是页面会直接跳转到登录页,而且会带上参数. --------------------------------------------分

  • vue从一个页面跳转到另一个页面并携带参数的解决方法

    1.需求: 点击商场跳转到商业体列表 解决方案: 元页面: a标签中添加跳转函数 <a class="orderBtn1 sIRicon2" href="javascript:void(0);" rel="external nofollow" @click="toMallInfo('M000989')"><i class="sIRicon"></i>商场</a>

  • Vue实现路由跳转和嵌套

    一.配置 Router 用 vue-cli 创建的初始模板里面,并没有 vue-router,需要通过 npm 安装 cnpm i vue-router -D 安装完成后,在 src 文件夹下,创建一个 routers.js 文件,和 main.js 平级 然后在 router.js 中引入所需的组件,创建 routers 对象 import Home from './components/home.vue' const routers = [ { path: '/home', name: 'h

  • 详解vue 路由跳转四种方式 (带参数)

    1.  router-link 1. 不带参数 <router-link :to="{name:'home'}"> <router-link :to="{path:'/home'}"> //name,path都行, 建议用name // 注意:router-link中链接如果是'/'开始就是从根路由开始,如果开始不带'/',则从当前路由开始. 2.带参数 <router-link :to="{name:'home', para

随机推荐