vue实现侧边定位栏

本文实例为大家分享了vue实现侧边定位栏的具体代码,供大家参考,具体内容如下

实现思路:

1.通过点击侧边栏,定位到响应的内容
2.滑动滑动栏,侧边栏同步高亮对应的item

效果图如下:

1. 通过点击侧边栏,定位到响应的内容

如果是用html的话我们可以用 锚点 的办法进行定位;
在vue中,我们可以通过获取组件的高度,将滑动栏定位到对应的位置

在进入主题之前我们需要先了解3个关于获取高度的属性

1.scrollTop 滑动栏中的滑块离视区最顶部的距离

document.documentElement.scrollTop || document.body.scrollTop

2.clientHeight 视区的高度

document.documentElement.clientHeight || document.body.clientHeight

3.scrollHeight 滑动栏里面的滑动块的高度

document.documentElement.scrollHeight || document.body.scrollHeight

vue中我们可以通过this.$refs.xxx.$el.offsetTop获取组件距离页面最顶部的距离,通过赋值给document.documentElement.scrollTop选中组件距离页面最顶部的高度,控制滑动框滑到页面对应位置。相关代码如下:

页面代码

// 页面组件代码
<div>
    <btl-header />
    <div class="reports">
      <side-bar v-bind="sideBarData" />
      <div class="main">
        <live-overview-part
          ref="liveOverview"
          :shopNameOptions="allShopName"
          :dateSelectorData="dateType_0" />
        <procurenment-alert
          ref="procurenmentAlert"
          :carBrandOptions="carBrandOptions"
          :shopNameOptions="allShopName"
          :dateSelectorData="dateType_2" />
        <sales-overview
          ref="salesOverview"
          :shopNameOptions="allShopName"
          :dateSelectorData1="pardsType_0"
          :dateSelectorData2="dateType_1" />
        <inquiry-data
          ref="inquiryData"
          :shopNameOptions="allShopName"
          :dateSelectorData="dateType_2" />
        <transaction-data
          ref="transactionData"
          :carBrandOptions="carBrandOptions"
          :shopNameOptions="allShopName"
          :qualityOptions="qualityOptions"
          :colorSeries="colorSeries"
          :dateSelectorData="dateType_2" />
      </div>
    </div>

//  获取组件距离页面顶部高度 !!!
 <script>
mounted() {
    // !!注意,需要页面渲染完才能获取各个盒子的高度
    this.sideBarData.offsetTopliveOverview = this.$refs.liveOverview.$el.offsetTop;
    this.sideBarData.offsetTopprocurenmentAlert = this.$refs.procurenmentAlert.$el.offsetTop;
    this.sideBarData.offsetTopsalesOverview = this.$refs.salesOverview.$el.offsetTop;
    this.sideBarData.offsetTopinquiryData = this.$refs.inquiryData.$el.offsetTop;
    this.sideBarData.offsetToptransactionData = this.$refs.transactionData.$el.offsetTop;
   },
  </script>

侧边栏实现代码

// 侧边栏代码
<template>
  <hn-card class="sidebar">
    <ul class="nav-tabs">
      <li
        class="activeTip"
        ref="activeTip"></li>
      <li
        @click="clickanchor('liveOverview',0)"
        class="item"
        :class="active==='liveOverview'?'active':'noActive'">实时总览</li>
      <li
        class="item"
        :class="active==='procurenmentAlert'?'active':'noActive'"
        @click="clickanchor('procurenmentAlert',1)">采购预警</li>
      <li
        class="item"
        :class="active==='salesOverview'?'active':'noActive'"
        @click="clickanchor('salesOverview',2)">销售概览</li>
      <li
        class="item"
        :class="active==='inquiryData'?'active':'noActive'"
        @click="clickanchor('inquiryData',3)">询价数据</li>
      <li
        class="item"
        :class="active==='transactionData'?'active':'noActive'"
        @click="clickanchor('transactionData',4)">交易数据</li>
      <li
        class="item"
        :class="active==='top'?'active':'noActive'"
        @click="clickanchor('top')">返回顶部</li>
    </ul>
  </hn-card>
</template>

// 侧边栏js
<script>
methods: {
// 点击侧边栏item时触发
// 通过document.documentElement.scrollTop控制滑动栏位置
    clickanchor(itemName, i) {
      if (itemName === 'top') {
        document.documentElement.scrollTop = 0; // 滑动栏位置
        this.active = itemName;
        this.$refs.activeTip.style.transform = `translateY(${196}px)`;
        return;
      }
      this.$refs.activeTip.style.transform = `translateY(${i * 39}px)`;
      document.documentElement.scrollTop = this[`offsetTop${itemName}`];
      this.active = itemName;
    },
</script>

2. 滑动滑动栏,侧边栏同步高亮对应的item

通过监听滑动栏滑动,获取滑动块距离页面顶部的高度,和组件距离页面顶部的高度进行对比,反向设置滑动栏的高亮位置;

// 监听滑动栏滚动,通过监听滚动到的位置,到
    scrollChange() {
      const scrollTop = document.documentElement.scrollTop || document.body.scrollTop || 0;
      const windowHeight = document.documentElement.clientHeight || document.body.clientHeight || 0;
      const scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight || 0;
      const allContentOffsettop = [
        'offsetTopliveOverview',
        'offsetTopprocurenmentAlert',
        'offsetTopsalesOverview',
        'offsetTopinquiryData',
        'offsetToptransactionData'];
      if (scrollTop === 0) {
        if (this.active !== 'top') {
          this.active = 'top';
          this.$refs.activeTip.style.transform = `translateY(${196}px)`;
        }
      } else if (scrollTop + windowHeight > scrollHeight || scrollTop + windowHeight === scrollHeight) {
        if (this.active !== 'transactionData') {
          this.active = 'transactionData';
          this.$refs.activeTip.style.transform = `translateY(${157}px)`;
        }
      } else {
        for (let i = 0; i < allContentOffsettop.length; i++) {
          if (this[allContentOffsettop[i]] - 1 > scrollTop) {
            const contentName = allContentOffsettop[i - 1].replace('offsetTop', '');
            if (this.active !== contentName) {
              this.active = contentName;
              this.$refs.activeTip.style.transform = `translateY(${(i - 1) * 39}px)`;
            }
            break;
          }
        }
      }
    },
  },
};

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

(0)

相关推荐

  • vue+elementUI组件递归实现可折叠动态渲染多级侧边栏导航

    早就实现了功能,但是发现点击的时候,选中的菜单项背景色会变白,周五时候仔细观察了一下,发现并不是调整样式的问题,而是选项没有被选中,于是好好研究了一下组件递归这块,总结记录一下心路历程 一.概念 递归:递归其实说白了,就是自己调用自己,样子就像是套娃一个套一个的,小时候玩过一个游戏汉诺塔就是利用的递归原理: 函数递归:函数利用函数名还调用自己 组件递归:所以组件递归利用的是vue组件中的name属性来实现的 二.需求 实现可折叠动态渲染多级侧边栏导航 三.分析 1.观察到侧边栏导航是一级一级的,

  • vue侧边栏动态生成下级菜单的方法

    循环传入的数据去生成下级菜单 <template> <div class="headBar"> <div class="title"> 微商城管理后台 </div> <el-menu class="el-menu-headBar" mode="horizontal" @select="handleSelect" background-color=&quo

  • vue实现多级侧边栏的封装

    本文实例为大家分享了vue实现多级侧边栏的封装代码,供大家参考,具体内容如下 父组件 // 左侧导航菜单封装 <template>   <div class="nav">     <Menu @handleLink="handleLink" :list="list">     </Menu>     <div>{{value}}</div>   </div> &l

  • VuePress 侧边栏的具体使用

    目录 前言 目录结构: 最简侧边栏: 侧边栏分组 显示文件名(或其他指定名字) 方法1 方法2 前言 官网写的侧边栏教程真的是让人很糟心,经过一番摸索,总算大致弄清楚了,下面详细说一下用法: 目录结构: docs根目录下有一个README.md.chinese文件夹.english文件夹 最简侧边栏: sidebar: { '/language/chinese/': [ '', //该目录下的README.md文件 'a', //该目录下的a.md文件 'b' //该目录下的a.md文件 ],

  • vue设置导航栏、侧边栏为公共页面的例子

    首先,项目结构如下: 想要让导航栏.侧边栏变为公共页面,则要在App.vue页面中加入.假设已经有了Header.vue和Left.vue,这里就不贴出来了,App.vue代码如下: <template> <div id="app"> <!-- 其他页 --> <el-container > <el-header> <!-- 导航栏 --> <header-nav></header-nav>

  • vue实现侧边栏导航效果

    本文实例为大家分享了vue侧边栏导航的具体代码,供大家参考,具体内容如下 最终效果 点击下一个导航,上一个导航自动收回 实现代码 1.下载vue-router npm install vue-router --save-dev 2.在main.js中引入 import Vue from 'vue' import Router from 'vue-router' Vue.use(Router) // 引入路由 3.在components中新建组件 3.1 agencySearch.vue组件 代码

  • vue实现侧边定位栏

    本文实例为大家分享了vue实现侧边定位栏的具体代码,供大家参考,具体内容如下 实现思路: 1.通过点击侧边栏,定位到响应的内容2.滑动滑动栏,侧边栏同步高亮对应的item 效果图如下: 1. 通过点击侧边栏,定位到响应的内容 如果是用html的话我们可以用 锚点 的办法进行定位:在vue中,我们可以通过获取组件的高度,将滑动栏定位到对应的位置 在进入主题之前我们需要先了解3个关于获取高度的属性 1.scrollTop 滑动栏中的滑块离视区最顶部的距离 document.documentEleme

  • Vue实现侧边导航栏于Tab页关联的示例代码

    目录 技术栈 效果 分析 技术栈 侧边栏用 Antdtab使用element 效果 <template> <div class="main-card"> <el-row> <el-col :span="3"> <div class="menu-all"> <div class="menu-head"> <span class="menu-h

  • vue实现中部导航栏布局功能

    接下来是中部导航栏.我们看到这里的头像动画,和中部导航栏定位都是跟鼠标滚动有关的.我们先将布局实现一下.这里是要求在页面上部分滚动范围内,导航栏一直在div的上部,随着鼠标的滚动而改变位置.到下部分滚动范围,导航栏就一直固定到页面的上部分. 这里需要注意两个地方 这里需要一个覆盖不了的区域,可以给人一种更好开关屏的感觉.而且中部导航栏下方区域的内容,在下滑的时候不能出现在这个区域. 一定要注意 尽可能的少进行DOM操作,这样是非常影响性能的 ! 监听鼠标滚动事件 private fixedFla

  • 微信小程序实现侧边分类栏

    本文实例为大家分享了微信小程序实现侧边分类栏的具体代码,供大家参考,具体内容如下 效果图 布局分析 分成三个盒子: 主盒子,左盒子,右盒子 –wxml– <!--主盒子--> <view class="container"> <!-- 左侧栏 --> <view class='nav_left'> <view class="nav_left_items {{curNav == 1 ? 'active' : ''}}&quo

  • bootstrap自定义样式之bootstrap实现侧边导航栏功能

    bootstrap自带的响应式导航栏是向下滑动的,有时满足不了个性化的需求,需要做一个类似于android drawerLayout 侧滑的菜单,这就是我要实现的bootstrap自定义侧滑菜单,参考了很多官网的侧滑,实现方法各有不同,优缺点也十分明显,有的官网首页为了仅仅实现一个侧滑的效果,用了owl.carousel滑屏的插件,个人觉得小题大做了.这个bootstrap侧滑菜单更专业的名字叫做手机导航栏.我也比较这个名字,更符合bootstrap的特性.所以我这篇文章介绍的更容易的一种做法,

  • jquery+css实现侧边导航栏效果

    最近做项目的时候,突然想用一个侧边导航栏,网上找了几个插件,有的太丑而且不太符合我的预期.与其修改别人的代码,不如自己来写一个了.废话不多说先上图,感兴趣的请继续看下去. 1.效果图 当有顶部导航栏的时候侧边导航栏会消失. 响应式方面,同样的顶部导航栏消失后右下角的图标才出现.点击出现导航,选中后消失: 这里是个demo ,没有做平滑滚动,需要的可以自己加上. 大体就介绍这么多吧,下面上代码. 2.css代码 这里是css代码,详情请看注释 <style> /*重置一些样式*/ *, *::a

  • vue.js 底部导航栏 一级路由显示 子路由不显示的解决方法

    最近利用vue第三方UI MuseUI开发webapp,然后在导航栏这里出现了问题,我需要在导航栏上的几个路由上显示底部导航栏,在其他路由上不显示,就这个问题,MuseUI的底部导航栏直接加载在app.vue里面,会每个页面都有导航栏,所以这种方式不可行,后来我真的使出了浑身解数,去MuseUI作者GitHub上面提问,无果,去segmentfault上面提问,无果,去vue官方群提问,无果,在提问之前,我都是经过一番搜索,思考的,但是这些都让我崩溃了.可能出错的地方从路由URL,museUI的

  • Vue实现侧边菜单栏手风琴效果实例代码

    效果图如下所示: <template> <div class="asideBox"> <aside> <ul class="asideMenu"> <li v-for="(item,index) in menuList"> <div class="oneMenu" @click="showToggle(item,index)"> <

  • vue自定义底部导航栏Tabbar的实现代码

    如图所示,要完成类似的一个底部导航切换. 首先.我们需要分为5个大的VUE文件.可以根据自己的习惯来放在不同的位置. 我将5个主要的vue文件放在了5个不同的文件夹 然后,在components文件夹里新建Tabbar.vue/以及Item.vue文件 Item.vue文件如下 <template> <div class="itemWarp flex_mid" @click='changePage'> <span v-show='!bol'> <

  • vue百度地图 + 定位的详解

    vue 百度地图 + 定位 前提需要自己有百度的密钥,如没有可以去百度地图申请 一.在主目录下的index.html引入js,例如:   二.在webpack.base.conf.js配置文件中配置BMap,在module.exports 中与entry平级,例如: 三.在项目中引入BMap: 四.代码: <template> <div class="home"> <div id="allmap" class="allmap&

随机推荐