mirror of https://github.com/ElemeFE/element
				
				
				
			
		
			
				
	
	
	
		
			10 KiB
		
	
	
	
	
			
		
		
	
	
			10 KiB
		
	
	
	
	
NavMenu
Menú que provee la navegación para tu sitio.
Top bar
Top bar NavMenu puede ser usado en distinto escenarios.
:::Demo Por defecto el menú es vertical, pero puedes hacerlo horizontal asignando a la propiedad mode el valor 'horizontal'. Además, puedes utilizar el componente de submenú para crear un menú de segundo nivel. Menú provee background-color, text-color y active-text-color para customizar los colores.
<el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect">
  <el-menu-item index="1">Processing Center</el-menu-item>
  <el-submenu index="2">
    <template slot="title">Workspace</template>
    <el-menu-item index="2-1">item one</el-menu-item>
    <el-menu-item index="2-2">item two</el-menu-item>
    <el-menu-item index="2-3">item three</el-menu-item>
  </el-submenu>
  <el-menu-item index="3"><a href="https://www.ele.me" target="_blank">Orders</a></el-menu-item>
</el-menu>
<div class="line"></div>
<el-menu
  :default-active="activeIndex2"
  class="el-menu-demo"
  mode="horizontal"
  @select="handleSelect"
  background-color="#545c64"
  text-color="#fff"
  active-text-color="#ffd04b">
  <el-menu-item index="1">Processing Center</el-menu-item>
  <el-submenu index="2">
    <template slot="title">Workspace</template>
    <el-menu-item index="2-1">item one</el-menu-item>
    <el-menu-item index="2-2">item two</el-menu-item>
    <el-menu-item index="2-3">item three</el-menu-item>
  </el-submenu>
  <el-menu-item index="3"><a href="https://www.ele.me" target="_blank">Orders</a></el-menu-item>
</el-menu>
<script>
  export default {
    data() {
      return {
        activeIndex: '1',
        activeIndex2: '1'
      };
    },
    methods: {
      handleSelect(key, keyPath) {
        console.log(key, keyPath);
      }
    }
  }
</script>
:::
Side bar
NavMenu vertical con sub-menús.
:::Demo Puedes utilizar el componente el-menu-item-group para crear un grupo de menú, y el nombre del grupo estará determinado por la propiedad title o la propiedad slot.
<el-row class="tac">
  <el-col :span="12">
    <h5>Default colors</h5>
    <el-menu
      default-active="2"
      class="el-menu-vertical-demo"
      @open="handleOpen"
      @close="handleClose">
      <el-submenu index="1">
        <template slot="title">
          <i class="el-icon-location"></i>
          <span>Navigator One</span>
        </template>
        <el-menu-item-group title="Group One">
          <el-menu-item index="1-1">item one</el-menu-item>
          <el-menu-item index="1-2">item one</el-menu-item>
        </el-menu-item-group>
        <el-menu-item-group title="Group Two">
          <el-menu-item index="1-3">item three</el-menu-item>
        </el-menu-item-group>
        <el-submenu index="1-4">
          <template slot="title">item four</template>
          <el-menu-item index="1-4-1">item one</el-menu-item>
        </el-submenu>
      </el-submenu>
      <el-menu-item index="2">
        <i class="el-icon-menu"></i>
        <span>Navigator Two</span>
      </el-menu-item>
      <el-menu-item index="3">
        <i class="el-icon-setting"></i>
        <span>Navigator Three</span>
      </el-menu-item>
    </el-menu>
  </el-col>
  <el-col :span="12">
    <h5>Custom colors</h5>
    <el-menu
      default-active="2"
      class="el-menu-vertical-demo"
      @open="handleOpen"
      @close="handleClose"
      background-color="#545c64"
      text-color="#fff"
      active-text-color="#ffd04b">
      <el-submenu index="1">
        <template slot="title">
          <i class="el-icon-location"></i>
          <span>Navigator One</span>
        </template>
        <el-menu-item-group title="Group One">
          <el-menu-item index="1-1">item one</el-menu-item>
          <el-menu-item index="1-2">item one</el-menu-item>
        </el-menu-item-group>
        <el-menu-item-group title="Group Two">
          <el-menu-item index="1-3">item three</el-menu-item>
        </el-menu-item-group>
        <el-submenu index="1-4">
          <template slot="title">item four</template>
          <el-menu-item index="1-4-1">item one</el-menu-item>
        </el-submenu>
      </el-submenu>
      <el-menu-item index="2">
        <i class="el-icon-menu"></i>
        <span>Navigator Two</span>
      </el-menu-item>
      <el-menu-item index="3">
        <i class="el-icon-setting"></i>
        <span>Navigator Three</span>
      </el-menu-item>
    </el-menu>
  </el-col>
</el-row>
<script>
  export default {
    methods: {
      handleOpen(key, keyPath) {
        console.log(key, keyPath);
      },
      handleClose(key, keyPath) {
        console.log(key, keyPath);
      }
    }
  }
</script>
:::
Collapse
NavMenu vertical puede ser colapsado.
:::Demo
<el-radio-group v-model="isCollapse" style="margin-bottom: 20px;">
  <el-radio-button :label="false">expand</el-radio-button>
  <el-radio-button :label="true">collapse</el-radio-button>
</el-radio-group>
<el-menu default-active="2" class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose" :collapse="isCollapse">
  <el-submenu index="1">
    <template slot="title">
      <i class="el-icon-location"></i>
      <span slot="title">Navigator One</span>
    </template>
    <el-menu-item-group>
      <span slot="title">Group One</span>
      <el-menu-item index="1-1">item one</el-menu-item>
      <el-menu-item index="1-2">item two</el-menu-item>
    </el-menu-item-group>
    <el-menu-item-group title="Group Two">
      <el-menu-item index="1-3">item three</el-menu-item>
    </el-menu-item-group>
    <el-submenu index="1-4">
      <span slot="title">item four</span>
      <el-menu-item index="1-4-1">item one</el-menu-item>
    </el-submenu>
  </el-submenu>
  <el-menu-item index="2">
    <i class="el-icon-menu"></i>
    <span slot="title">Navigator Two</span>
  </el-menu-item>
  <el-menu-item index="3">
    <i class="el-icon-setting"></i>
    <span slot="title">Navigator Three</span>
  </el-menu-item>
</el-menu>
<style>
  .el-menu-vertical-demo:not(.el-menu--collapse) {
    width: 200px;
    min-height: 400px;
  }
</style>
<script>
  export default {
    data() {
      return {
        isCollapse: true
      };
    },
    methods: {
      handleOpen(key, keyPath) {
        console.log(key, keyPath);
      },
      handleClose(key, keyPath) {
        console.log(key, keyPath);
      }
    }
  }
</script>
:::
Atributos Menu
| Atributo | Descripción | Tipo | Valores aceptados | Valores por defecto | 
|---|---|---|---|---|
| mode | modo de presentación del menú | string | horizontal / vertical | vertical | 
| collapse | si el menú está colapsado (solo en modo vertical) | boolean | — | false | 
| background-color | color de fondo del menú (formato hexadecimal) | string | — | #ffffff | 
| text-color | color de texto del menú (formato hexadecimal) | string | — | #2d2f33 | 
| active-text-color | color de text del menu-item activo (formato hexadecimal) | string | — | #409EFF | 
| default-active | índice del menu-item activo | string | — | — | 
| default-openeds | arreglo que contiene las llaves del sub-menus activo | Array | — | — | 
| unique-opened | whether only one sub-menu can be active | boolean | — | false | 
| menu-trigger | como dispara eventos sub-menus, solo funciona cuando modees 'horizontal' | string | — | hover | 
| router | si el modo vue-routerestá activado. Si es verdader, índice será usado como 'path' para activar la ruta | boolean | — | false | 
Métodos Menu
| Nombre de evento | Descripción | Parámetros | 
|---|---|---|
| open | abre un sub-menu específico | index: índice del sub-menu para abrir | 
| close | cierra un sub-menu específico | index: índice del sub-menu para cerrar | 
Eventos Menu
| Nombre de evento | Descripción | Parámetros | 
|---|---|---|
| select | callback ejecutado cuando el menú es activado | index: índice del menú activado, indexPath: index path del menú activado | 
| open | callback ejecutado cuando sub-menu se expande | index: índice del sub-menu expandido, indexPath: index path del sub-menu expandido | 
| close | callback ejecutado cuando sub-menu colapsa | index: índice del sub-menu colapsado, indexPath: index path del menú colapsado | 
Eventos Menu-Item
| Nombre de evento | Descripción | Parámetros | 
|---|---|---|
| click | callback ejecutado cuando se hace click sobre menu-item | el: instancia de menu-item | 
Atributos SubMenu
| Atributo | Descripción | Tipo | Valores aceptados | Valores por defecto | 
|---|---|---|---|---|
| index | identificador único | string | — | — | 
Atributos Menu-Item
| Atributo | Descripción | Tipo | Valores aceptados | Valores por defecto | 
|---|---|---|---|---|
| index | identificador único | string | — | — | 
| route | Object Vue Router | object | — | — | 
Atributos Menu-Group
| Atributo | Descripción | Tipo | Valores aceptados | Valores por defecto | 
|---|---|---|---|---|
| title | título del grupo | string | — | — |