vue实现导航收缩框

本文实例为大家分享了vue实现导航收缩框的具体代码,供大家参考,具体内容如下

代码:

<template>
  <div class="leftAside">
    <el-header style="height: 40px">
      <i class="el-icon-s-fold shousuo" @click="isC" v-show="block"></i>
      <i class="el-icon-s-unfold shousuo" @click="isC" v-show="toggle"></i>
    </el-header>

    <el-menu
      unique-opened
      router
      class="el-menu-vertical-demo el-menu-vertical menuboss"
      background-color="#fff"
      text-color="#fff"
      active-text-color="#2A62CE"
      default-active
      :collapse="isCollapse"
    >
      <el-menu-item index="/shouye">
        <i class="el-icon-s-home"></i>
        <span slot="title">首页</span>
      </el-menu-item>

      <el-submenu index="/terminal" v-hasPermi="['system:ca:ca']">
        <template slot="title">
          <i class="el-icon-connection"></i>
          <span> CA办理</span>
        </template>
        <el-menu-item index="/terminal" class="navds">新申请</el-menu-item>
        <el-menu-item index="/renewal" class="navds">续期</el-menu-item>
        <el-menu-item index="/reissued" class="navds">补办</el-menu-item>
        <el-menu-item index="/report" class="navds">挂失/取消挂失</el-menu-item>
        <el-menu-item index="/logout" class="navds">注销</el-menu-item>
        <el-menu-item index="/deblocking" class="navds">解锁</el-menu-item>
        <el-menu-item index="/support" class="navds">CA帮助中心</el-menu-item>
        <!-- <el-menu-item index="/settlement" class="navds">结算办理</el-menu-item>
        <el-menu-item index="/bill" class="navds">发票办理</el-menu-item>
        <el-menu-item index="/helpCenter" class="navds">结算办理</el-menu-item> -->
      </el-submenu>

      <el-menu-item index="/beihuo" v-hasPermi="['system:stockup:stockup']">
        <i class="el-icon-s-order"></i>
        <span slot="title">备货订单</span>
      </el-menu-item>
      <el-menu-item index="/fahuo" v-hasPermi="['system:shipnotice:shipnotice']">
        <i class="el-icon-s-promotion"></i>
        <span slot="title">发货通知单</span>
      </el-menu-item>
      <el-menu-item index="/tihuo" v-hasPermi="['system:delivery:delivery']">
        <i class="el-icon-document-checked"></i>
        <span slot="title">提货通知单</span>
      </el-menu-item>
      <el-menu-item index="/myjiesuan" v-hasPermi="['system:settlebill:settlebill']">
        <i class="el-icon-shopping-cart-full"></i>
        <span slot="title">结算单</span>
      </el-menu-item>
      <el-menu-item index="/myqiye">
        <i class="el-icon-office-building" v-hasPermi="['system:coinfomaint:coinfomaint']"></i>
        <span slot="title">企业信息维护</span>
      </el-menu-item>
      <el-menu-item index="/mytongji" v-hasPermi="['system:statistics:statistics']">
        <i class="el-icon-s-marketing"></i>
        <span slot="title">统计报表</span>
      </el-menu-item>
      <el-menu-item index="/mypingjia" v-hasPermi="['system:suppliereva:suppliereva']">
        <i class="el-icon-star-on"></i>
        <span slot="title">供应商评价</span>
      </el-menu-item>
      <el-menu-item index="myrenyuan" v-hasPermi="['system:supplierpm:supplierpm']">
        <i class="el-icon-s-custom"></i>
        <span slot="title">供应商人员管理</span>
      </el-menu-item>

      <el-submenu index="/electronic" v-hasPermi="['system:maintenance:tool']">
        <template slot="title">
          <i class="el-icon-suitcase-1"></i>
          <span> 运维工具</span>
        </template>
        <el-menu-item index="/electronic" v-hasPermi="['system:eseal:conf']" class="maintenance"
          >电子印章配置</el-menu-item
        >
      </el-submenu>
    </el-menu>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isCollapse: false, //导航栏默认为展开
      toggle: false, //第二个图标默认隐藏
      block: true //默认显示第一个图标
    }
  },
  methods: {
    // 动态控制展开与收起和切换对应图标
    isC() {
      this.isCollapse = !this.isCollapse
      this.toggle = !this.toggle
      this.block = !this.block
      // 把当前状态传给父组件 lay
      this.$emit('isCollapse', this.isCollapse)
    }
  }
}
</script>

<style lang="scss" scoped>
.el-menu-vertical:not(.el-menu--collapse) {
  width: 180px;
}
.leftAside {
  width: 180px;
  height: 100%;
  padding-top: 20px;
  overflow: auto;
  background-image: url('../../assets/update/imgs/bjleft.jpg');
  .el-header {
    .shousuo {
      cursor: pointer;
      color: #fff;
      opacity: 0.8;
      font-size: 20px;
      transition: 0.37s;
    }
    .shousuo:hover {
      font-size: 22px;
      transition: 0.37s;
    }
  }
  .el-menu {
    border-right: 0 !important;
    background-color: transparent !important;
  }
  ::v-deep.el-menu-item {
    height: 44px;
    line-height: 40px;
    background-color: transparent !important;

    i {
      width: 14px;
      height: 14px;
      margin-right: 15px;
      color: #fff !important;
    }
    img {
      width: 14px;
      height: 14px;
      line-height: 14px;
      margin-right: 15px;
      margin-left: 2px;
    }
  }
  .el-menu-item:hover {
    background: #2b5dbe !important;
    border-radius: 10px 0px 0px 10px;
  }
  .el-menu-item.is-active {
    background: #f5f5f5 !important;
    border-radius: 10px 0px 0px 10px;

    i {
      color: #2a62ce !important;
    }
  }
  ::-webkit-scrollbar {
    display: none !important;
  }
}
::v-deep .el-submenu__title {
  height: 44px;
  line-height: 40px;
  background-color: transparent !important;
  i {
    width: 14px;
    height: 14px;
    margin-right: 15px;
    color: #fff !important;
  }
  img {
    width: 14px;
    height: 14px;
    line-height: 14px;
    margin-right: 15px;
    margin-left: 2px;
  }
}
::v-deep .el-menu--inline {
  background: #1444aa !important;
}
</style>

在路由出口页面
   <LeftNav @isCollapse="isCollapse"></LeftNav>
  methods:{
    // 接收子组件leftnav的值 进行宽度动态化
    isCollapse(val){
      console.log("父组件",val);
      if(val===false){
          this.asidewidth="180px"
      }else{
        this.asidewidth="60px"
      }
    }
  }

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

(0)

相关推荐

  • vue router导航守卫(router.beforeEach())的使用详解

    导航守卫 导航守卫主要用来通过跳转或取消的方式守卫导航.有多种机会植入路由导航过程中:全局的, 单个路由独享的, 或者组件级的.(记住参数或查询的改变并不会触发进入/离开的导航守卫.你可以通过观察$route对象来应对这些变化,或使用beforeRouteUpdate的组件内守卫.) 好久没写一些东西了,总是感觉有啥缺少的.~~~~恰好碰到最近在写一个移动端项目,遇到了如何使同一个链接在不同条件下跳转到不同路由组件问题,譬如大家经常看到手机中没登录跳转登录页,登陆后跳转个人信息页等.废话不多说了

  • vue 和vue-touch 实现移动端左右导航效果(仿京东移动站导航)

    先给大家展示下效果图,感觉还不错请参考实现代码: 使用技术:vue2.0 webpack vue-touch 一些简单的javascript; (注意:vue-touch 使用的是2.0.0版本 需要与vue2.0.0兼容) vue-touch(地址:https://github.com/vuejs/vue-touch 注意是next 分支) 左侧导航可滑动(右侧视图窗因为和左逻辑一样 就没写) var VueTouch = require('vue-touch') Lib.Vue.use(Vu

  • 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组件 代码

  • vue2.0实现导航菜单切换效果

    本文实例为大家分享了vue2.0实现导航菜单切换的具体代码,供大家参考,具体内容如下 css *{ margin:0; padding: 0; } ul li{ list-style: none; } .navul{ margin:100px auto 20px; overflow: hidden; } .navul li{ background-color: #5597b4; padding:18px 30px; float:left; color: #fff; font-size: 18px

  • Vue实现导航栏菜单

    本文实例为大家分享了Vue实现导航栏菜单的具体代码,供大家参考,具体内容如下 这里是刚学习vue的时候,没有用vue的任何UI组件库写的导航栏菜单. menu.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>导航栏左</title> <link rel="stylesheet" href="css/

  • 详解Vue的钩子函数(路由导航守卫、keep-alive、生命周期钩子)

    前言 说到Vue的钩子函数,可能很多人只停留在一些很简单常用的钩子(created,mounted),而且对于里面的区别,什么时候该用什么钩子,并没有仔细的去研究过,且Vue的生命周期在面试中也算是比较高频的考点,那么该如何回答这类问题,让人有眼前一亮的感觉呢... Vue-Router导航守卫: 有的时候,我们需要通过路由来进行一些操作,比如最常见的登录权限验证,当用户满足条件时,才让其进入导航,否则就取消跳转,并跳到登录页面让其登录. 为此我们有很多种方法可以植入路由的导航过程:全局的, 单

  • vue使用ElementUI时导航栏默认展开功能的实现

    本文主要参考: http://element.eleme.io/#/zh-CN/component/menu 在使用elementUI的时候发现,能够展开的导航栏是不能展开的,效果这里先不演示了.可以在上边的网站上看到. 现在有这样的需求,就是说,默认的时候需要展开这些导航,就是一打开界面的时候就能够显示导航里面的菜单内容. 具体操作是这样的: <script src="//unpkg.com/vue/dist/vue.js"></script> <scr

  • vue+elementUI动态生成面包屑导航教程

    效果如下所示: 项目需要动态生成面包屑导航,并且首页可以点击.其余为路径显示 <el-menu :unique-opened="true" router :default-active="$route.path" @select="handleSelect"> <div class="user-menu-box" v-for="menu in menus" :key="menu.

  • vue实现nav导航栏的方法

    每一个网页项目都少不了导航栏,通过原始的方法基本上都是可以写出来的.但是要写出代码量少,冗余度低的代码就要动脑子思考一下了. 最近写了一个百度地图的项目,要求底部有一个导航栏.具体如下图: 首先,拿到了底部导航栏的所有图标图片,图片都有两种.灰色的代表未选中,选中的用带样色的图片替换. 先看一下,组件中 html结构:通过vue提供的v-for方法,进行遍历显示footNav这个数组.数组里边存放着{title:"银行",url:" ",url1:" &q

  • vue实现导航栏效果(选中状态刷新不消失)

    Vue导航栏 用Vue写手机端的项目,经常会写底部导航栏,我这里总结一套比较方便实用的底部导航栏方法,并且可以解决浏览器刷新选中状态消失的问题.也可以选择自适应屏幕.看一下效果,底部的图标全是UI给的选中和未选中样式的图片,根据公司要求,你也可能会用fontsize去写.(全部代码黏贴到本文的最后面了) 1.首先把这些小图片放到src/assets路径下面(自动base64编码) 2.在data()里边定义一个选中对应的变量isSelect,和循环遍历的数组,数组下面放图标对应的文字,和选中,未

随机推荐