element-ui的NavMenu置于顶部(mode="horizontal")时,让菜单可以滚动(overflow-x:auto)(主要用于移动端的菜单显示)...

在移动端项目中,使用Element-UI的NavMenu组件时,当菜单项过多导致无法在顶部横向展示,通过设置`overflow-x: auto`及调整宽度实现菜单滚动效果。遇到的问题和解决方案详述。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

说实话,写样式看似简单,其实有时候也会遇到很多坑。留下一笔,供参考(有点啰嗦,可以直接拖到最后看最后两行)。

这次是做一个PC端和移动端同时适用的项目,菜单的展示就成了一个问题。

  于是我判断了用户设备(具体见本人的另一篇随笔:https://www.cnblogs.com/nuonuo-D/p/10516626.html),设了一个变量isMobi(移动端值为true,PC端值为false),菜单我用的是element-ui 的NavMenu,拟在pc端展示在页面左侧,移动端展示在页面顶部。也就是说,思路是这样:

    isMobi?mode='horizontal':mode='vertical' (即移动端:NavMenu的模式为horizontal,pc端模式为vertical)

    此外再调整相应的css

  好了废话不多说,随着项目的迭代,菜单从原先的三个变成了六七个,移动端一屏已经无法显示。于是我就想着让它出滚动条。

  本来以为单纯加个overflow-x:auto就能解决了,结果发现并不能。

  经过几次尝试,得到的解决方法:

  代码(快捷阅读:看红色文字即可):

<template>
  <div class="sidebar-top">
    <el-menu
      :mode="mode"
      :collapse-transition="false"
      :default-active="onRoutes"
      v-bind:router="true"
      background-color="#3b3b3b"
      text-color="#fff"
      :unique-opened="true"
      menu-trigger="click"
      active-text-color="#20a0ff">
      <template>
        <el-menu-item index="/index">
          <span slot="title">首页</span>
        </el-menu-item>
      </template>
      <template>
      <el-submenu index="1">
        <template slot="title">
          <span>一级菜单1</span>
        </template>
        <el-menu-item index="/url1" >二级菜单1</el-menu-item>
      </el-submenu>
    </template>
      <template>
        <el-submenu index="2">
          <template slot="title">
            <span >一级菜单2</span>
          </template>
          <el-submenu index="2-1" :popper-append-to-body="true" >
            <span slot="title">带三级菜单的二级菜单</span>
            <el-menu-item index="/url">三级菜单1</el-menu-item>
            <el-menu-item index="/url">三级菜单2</el-menu-item>
          </el-submenu>
        </el-submenu>
      </template>
      <template>
        <el-submenu index="3">
          <template slot="title">
            <span>一级菜单3</span>
          </template>
          <el-menu-item index="/url1" >二级菜单1</el-menu-item>
          <el-menu-item index="/url2" >二级菜单2</el-menu-item>
        </el-submenu>
      </template>
      <template>
        <el-submenu index="4">
          <template slot="title">
            <span>一级菜单4</span>
          </template>
          <el-menu-item index="/url1" >二级菜单1</el-menu-item>
        </el-submenu>
      </template>
      <template>
        <el-submenu index="5">
          <template slot="title">
            <span>一级菜单5</span>
          </template>
          <el-menu-item index="/url1" >二级菜单1</el-menu-item>
        </el-submenu>
      </template>
      <template>
        <el-menu-item index="/url1">
          <span slot="title">一级菜单6</span>
        </el-menu-item>
      </template>
    </el-menu>
  </div>
</template>
<!--注:设置:popper-append-to-body="true" 可以防止三级菜单跑到屏幕外面去-->
 
 

 

  样式(快捷阅读:看红色文字即可):

<style>
  .sidebar-top{
    background-color: #3b3b3b;
    height: 55px;
    overflow-x: auto;
  }
  .sidebar-top > ul {
    /*width: 840px;*//*带icon的*/
    width: 530px;/*不带icon的*/
  }
  .sidebar-top .el-menu--horizontal>.el-menu-item {
    height: 55px;
    line-height: 55px;
  }
  .sidebar-top .el-menu--horizontal>.el-submenu .el-submenu__title {
    height: 55px;
    line-height: 55px;
  }
  .sidebar-top .el-submenu .el-menu-item {
    min-width: 160px;
  }
  .sidebar-top .el-menu--collapse .el-menu .el-submenu,.el-menu--popup {
    min-width: 100px;
  }
  .el-submenu__icon-arrow {
    margin-top: -4px;
  }

  .el-submenu .el-menu-item {
    min-width: 80px;
  }
  .iconfont{
    font-size: 20px;
  }

</style>

 总结:代码放了很多,因为本人说事情可能下意识的想全面点(代码可以直接复制看效果)所以不够精简,关键点只有几个:

  1.el-menu的父容器加上属性:overflow-x: auto;

  2.el-menu设好宽度,这个宽度的大小约为所有二级菜单宽度之和

 

转载于:https://www.cnblogs.com/nuonuo-D/p/10900904.html

在vue2中el-popover失效,刷新页面后正常显示el-popover在子组件中,子组件中部分代码:<p v-if="!userName"> <el-popover placement="bottom-start" trigger="hover"> <div class="nav-game"> <ul> <li><el-button class="nav-avatar" type="primary" @click="gotoLogin()">登录</el-button></li> <li><el-link class="nav-avatar" type="primary" @click="gotoRegister()">用户注册</el-link></li> </ul> </div> <el-avatar slot="reference" size="medium" icon='el-icon-user-solid' src="https://i0.hdslb.com/bfs/face/9e684120bdf30f9c7130de8b3f3b004e589f46ef.jpg@96w_96h_1c.webp" ></el-avatar> </el-popover> </p> <p v-else> <el-popover placement="bottom-start" trigger="hover"> <div class="nav-game"> <ul> <li class="nav-a-text"> 用户名:{{ userInfo.name }} </li> <li class="nav-a-text"> id:{{ userInfo.u_id }} </li> <li> <el-menu :default-active="activeIndex" class="el-menu-demo nav-a-item" mode="horizontal" @select="handleSelect"> <el-menu-item index="1" style="border-bottom:none;"> <h3 class="nav-a-num">{{ userInfo.like_num }}</h3> <p class="nav-a-word">点赞</p> </el-menu-item> <el-menu-item index="2"> <h3 class="nav-a-num">{{ userInfo.fans_num }}</h3> <p class="nav-a-word">粉丝</p> </el-menu-item> <el-menu-item index="3"> <h3 class="nav-a-num">{{ userInfo.issue_num }}</h3> <p class="nav-a-word">作品</p> </el-menu-item> </el-menu> </li> <li> <el-menu class="el-menu-vertical-demo" :router="true" style="margin-top: 20px; border-right: none;"> <el-menu-item index="/center"> <i class="el-icon-user" style="color: blue"></i> <span slot="title" class="nav-a-affair">个人中心</span> </el-menu-item> <el-menu-item index="/center"> <i class="el-icon-tickets" style="color: blue"></i> <span slot="title" class="nav-a-affair">稿件中心</span> </el-menu-item> <div style="width: 100%;height: 2px;background-color: gray;"></div> <el-menu-item index="" @click="logout()"> <i class="el-icon-close" style="color: blue"></i> <span slot="title" class="nav-a-affair">退出登入</span> </el-menu-item> </el-menu> </li> </ul> </div> <div slot="reference"> <Avatar :asize="40"></Avatar> </div> </el-popover>
03-30
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值