返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue实现多级侧边栏的封装
  • 582
分享到

vue实现多级侧边栏的封装

2024-04-02 19:04:59 582人浏览 薄情痞子
摘要

本文实例为大家分享了Vue实现多级侧边栏的封装代码,供大家参考,具体内容如下 父组件 // 左侧导航菜单封装 <template>   <div class="na

本文实例为大家分享了Vue实现多级侧边栏的封装代码,供大家参考,具体内容如下

父组件

// 左侧导航菜单封装
<template>
  <div class="nav">
    <Menu @handleLink="handleLink" :list="list">
    </Menu>
    <div>{{value}}</div>
  </div>
</template>

<script>
import Menu from '@/components/Menu.vue'
  export default {
    components:{
      Menu
    },
    data(){
      return {
        value: '',
        list: [
          {
            name: '导航1',
            child: [
              {
                name: '选项1',
                child: [
                  {
                    name: '选项1-1',
                    url: 'aaa-1'
                  },
                  {
                    name: '选项2-1',
                    url: 'bbb-1'
                  },
                  {
                    name: '选项3-1',
                    url: 'ccc-1'
                  },
                ]
              },
              {
                name: '选项2',
                url: 'bbb'
              },
              {
                name: '选项3',
                url: 'ccc'
              },
              {
                name: '选项4',
                url: 'DDD'
              },
            ]
          },
          {
            name: '导航2',
            child: [
              {
                name: '选项1',
                url: 'aaa'
              },
              {
                name: '选项2',
                url: 'bbb'
              },
            ]
          },
          {
            name: '导航3',
            url: 'eee'
          },
          {
            name: '导航4',
          }
        ]
      }
    },
    
    methods: {
      handleLink($event,item,index){
        if(item.url){
          this.value = '跳转到' + item.url
        } else {
          if(item.isOpen == undefined){
            this.$set(item,'isOpen', true)
          } else {
            item.isOpen = !item.isOpen
          }
        }
      }
    }
  }
</script>

<style lang="less" scoped>
  *{
    margin: 0;
    padding: 0;
  }
  .nav{
    display: flex;
  }

</style>

子组件

<template>
    <!-- 递归封装多级菜单栏 -->
    <div class="navMenu">
        <div
            v-for="(item, index) in list"
            class="item"
            @click.stop.prevent="handleLink($event, item, index)"
        >
            <div
                class="item-cont"
                :class="{ 'is-disabled': !(item.url || item.child) }"
            >
                {{ item.name }}
                <i class="icon" v-if="item.child"></i>
            </div>
            <div class="list-child" :class="{ active: !item.isOpen }" v-if="item.child">
                <Menu
                    :list="item.child"
                    @handleLink="handleLink"
                ></Menu>
            </div>
        </div>
    </div>
</template>

<script>
export default {
    name: "Menu",
    props: {
        list: {
            type: Array,
            default: [],
        },
    },
    methods: {
        handleLink($event, item, index) {
            this.$emit("handleLink", $event, item, index);
        },
    },
};
</script>

<style lang="less" scoped>
.navMenu {
    height: auto;
    background: #fff;
    cursor: pointer;
    .item {
        width: 200px;
        color: black;
        .child,
        .item-cont {
            min-height: 50px;
            line-height: 50px;
            position: relative;
            &:hover {
                background: #94bce4;
            }
            &.is-disabled {
                opacity: 0.25;
                cursor: not-allowed;
            }
            .icon {
                content: "";
                border: 8px solid;
                border-color: #f00 transparent transparent transparent;
                position: absolute;
                top: calc(50% - 4px);
                right: 0;
            }
        }
        .list-child {
            margin-left: 30px;
            &.active {
                display: none;
            }
        }
    }
}
</style>

效果图

复制粘贴即可使用

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

--结束END--

本文标题: vue实现多级侧边栏的封装

本文链接: https://lsjlt.com/news/164324.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue实现多级侧边栏的封装
    本文实例为大家分享了vue实现多级侧边栏的封装代码,供大家参考,具体内容如下 父组件 // 左侧导航菜单封装 <template>   <div class="na...
    99+
    2024-04-02
  • vue实现侧边定位栏
    本文实例为大家分享了vue实现侧边定位栏的具体代码,供大家参考,具体内容如下 实现思路: 1.通过点击侧边栏,定位到响应的内容2.滑动滑动栏,侧边栏同步高亮对应的item 效果图如下...
    99+
    2024-04-02
  • vue如何实现侧边定位栏
    今天小编给大家分享一下vue如何实现侧边定位栏的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。实现思路:通过点击侧边栏,定位到...
    99+
    2023-07-02
  • vue+elementUI组件递归实现可折叠动态渲染多级侧边栏导航
    早就实现了功能,但是发现点击的时候,选中的菜单项背景色会变白,周五时候仔细观察了一下,发现并不是调整样式的问题,而是选项没有被选中,于是好好研究了一下组件递归这块,总结记录一下心路历...
    99+
    2024-04-02
  • 微信小程序实现侧边栏二级联动
    本文实例为大家分享了微信小程序实现侧边栏二级联动的具体代码,供大家参考,具体内容如下 实现效果如下 实现步骤 样式布局(.wxml文件) <scroll-view scrol...
    99+
    2024-04-02
  • JavaScript仿淘宝实现固定右侧侧边栏
    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"&g...
    99+
    2024-04-02
  • bootstrap侧边导航栏实现原理
    这篇文章主要介绍bootstrap侧边导航栏实现原理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!bootstrap自带的响应式导航栏是向下滑动的,有时满足不了个性化的需求,需要做一个类似于android drawe...
    99+
    2023-06-14
  • 原生JS实现分享侧边栏
    本文分享一个用原生JS实现的分享侧边栏,实现效果如下: 以下是代码实现,方便大家复制粘贴。 <!DOCTYPE html> <html> <h...
    99+
    2024-04-02
  • js实现淘宝固定侧边栏
    本文实例为大家分享了js实现淘宝固定侧边栏的具体代码,供大家参考,具体内容如下 1.实现效果: 当页面运行到banner区域时,右边侧边栏改为固定定位,当页面运行到主体区域时,右边...
    99+
    2024-04-02
  • 小程序实现侧边栏切换
    本文实例为大家分享了小程序实现侧边栏切换的具体代码,供大家参考,具体内容如下 效果图如下: 实现步骤: sort.wxml <!--主盒子--> <view cl...
    99+
    2024-04-02
  • Wordpress实现自带的侧边栏和自定义的侧边栏同时存在的方法
    本文实例讲述了Wordpress实现自带的侧边栏和自定义的侧边栏同时存在的方法。分享给大家供大家参考。具体如下: 可能使用wordpress的朋友会发现我们使用自定左侧栏时系统自带的左侧栏就不能显示了,这两几乎不能同时存...
    99+
    2022-06-12
    Wordpress 自带 自定义 侧边栏 同时存在 方法
  • Vue如何实现侧边导航栏于Tab页关联
    这篇文章主要为大家展示了“Vue如何实现侧边导航栏于Tab页关联”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue如何实现侧边导航栏于Tab页关联”这篇文章吧。技术栈侧边栏用Antdtab使用...
    99+
    2023-06-25
  • 如何用vue实现一个侧边栏拖动功能
    这篇文章主要介绍了如何用vue实现一个侧边栏拖动功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何用vue实现一个侧边栏拖动功能文章都会有所收获,下面我们一起来看看吧。首先,需要安装 Vue.js,可以使用...
    99+
    2023-07-05
  • 微信小程序如何实现侧边栏二级联动
    今天小编给大家分享一下微信小程序如何实现侧边栏二级联动的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。实现效果如下实现步骤样式...
    99+
    2023-07-02
  • JavaScript如何仿淘宝实现固定右侧侧边栏
    这篇文章主要介绍了JavaScript如何仿淘宝实现固定右侧侧边栏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。<!DOCTYPE html><h...
    99+
    2023-06-29
  • Vue实现侧边导航栏于Tab页关联的示例代码
    目录技术栈效果分析技术栈 侧边栏用 Antdtab使用element 效果 <template> <div class="main-...
    99+
    2024-04-02
  • js如何实现淘宝固定侧边栏
    这篇文章主要介绍“js如何实现淘宝固定侧边栏”,在日常操作中,相信很多人在js如何实现淘宝固定侧边栏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”js如何实现淘宝固定侧边栏”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-02
  • 小程序如何实现侧边栏切换
    这篇文章主要介绍了小程序如何实现侧边栏切换的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇小程序如何实现侧边栏切换文章都会有所收获,下面我们一起来看看吧。效果图如下:实现步骤:sort.wxml<!--主盒...
    99+
    2023-07-02
  • 微信小程序实现侧边导航栏
    本文实例为大家分享了微信小程序实现侧边导航栏的具体代码,供大家参考,具体内容如下 效果图 wxml <view class='productNav'>   <!-...
    99+
    2024-04-02
  • 微信小程序实现滑动侧边栏
    本文实例为大家分享了微信小程序滑动侧边栏的具体代码,供大家参考,具体内容如下 效果图: 手指向右滑动可以显示侧边栏,向左滑动隐藏侧边栏 代码附上:.wxml <view cl...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作