mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-15 01:41:20 +08:00
a856c463bb
* feat(dropdown): add type 'contextmenu' trigger for dropdown #961 * docs(dropdown): update dropdown trigger doc Co-authored-by: wenyu.zhou <wenyu.zhou@huolala.cn>
345 lines
12 KiB
Markdown
345 lines
12 KiB
Markdown
## Dropdown
|
|
Menú conmutable para visualizar listas de enlaces y acciones.
|
|
|
|
### Uso básico
|
|
Pase el ratón por el menú desplegable para desplegarlo y obtener más acciones.
|
|
|
|
:::demo El elemento desencadenante se representa con el slot predeterminado, y la parte desplegable se representa con el slot llamado dropdown. Por defecto, la lista desplegable se muestra cuando se pasa el ratón por encima del elemento desencadenante sin necesidad de hacer clic en él.
|
|
|
|
```html
|
|
<el-dropdown>
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item disabled>Action 4</el-dropdown-item>
|
|
<el-dropdown-item divided>Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<style>
|
|
.el-dropdown-link {
|
|
cursor: pointer;
|
|
color: #409EFF;
|
|
}
|
|
.el-icon-arrow-down {
|
|
font-size: 12px;
|
|
}
|
|
</style>
|
|
|
|
```
|
|
|
|
:::
|
|
|
|
### Elemento detonante
|
|
|
|
Utilizando un botón para activar la lista desplegable.
|
|
|
|
:::demo Utilice `split-button` para dividir el elemento detonante en un grupo de botones, siendo el botón izquierdo un botón normal y el botón derecho el objetivo real de la detonacion. Si desea insertar una línea de separación entre la posición tres y la posición cuatro, sólo añada un divisor de clase a la posición cuatro.
|
|
|
|
```html
|
|
<el-dropdown>
|
|
<el-button type="primary">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</el-button>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
<el-dropdown-item>Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
<el-dropdown split-button type="primary" @click="handleClick">
|
|
Dropdown List
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
<el-dropdown-item>Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<style>
|
|
.el-dropdown {
|
|
vertical-align: top;
|
|
}
|
|
.el-dropdown + .el-dropdown {
|
|
margin-left: 15px;
|
|
}
|
|
.el-icon-arrow-down {
|
|
font-size: 12px;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
export default {
|
|
methods: {
|
|
handleClick() {
|
|
alert('button click');
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
```
|
|
:::
|
|
|
|
### Cómo detonar el evento
|
|
|
|
Haga clic en el elemento detonante o sobre él.
|
|
|
|
:::demo Utilice el atributo `trigger`. Por defecto, es `hover`.
|
|
|
|
```html
|
|
<el-row class="block-col-2">
|
|
<el-col :span="8">
|
|
<span class="demonstration">hover to trigger</span>
|
|
<el-dropdown>
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item icon="el-icon-plus">Action 1</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus">Action 2</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus-outline">Action 3</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-check">Action 4</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-check">Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
</el-col>
|
|
<el-col :span="8">
|
|
<span class="demonstration">click to trigger</span>
|
|
<el-dropdown trigger="click">
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item icon="el-icon-plus">Action 1</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus">Action 2</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus-outline">Action 3</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-check">Action 4</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-check">Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
</el-col>
|
|
<el-col :span="8">
|
|
<span class="demonstration">right click to trigger</span>
|
|
<el-dropdown trigger="contextmenu">
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item icon="el-icon-plus">Action 1</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus">Action 2</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-plus-outline">Action 3</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-check">Action 4</el-dropdown-item>
|
|
<el-dropdown-item icon="el-icon-circle-check">Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
</el-col>
|
|
</el-row>
|
|
|
|
<style>
|
|
.el-dropdown-link {
|
|
cursor: pointer;
|
|
color: #409EFF;
|
|
}
|
|
.el-icon-arrow-down {
|
|
font-size: 12px;
|
|
}
|
|
.demonstration {
|
|
display: block;
|
|
color: #8492a6;
|
|
font-size: 14px;
|
|
margin-bottom: 20px;
|
|
}
|
|
</style>
|
|
```
|
|
:::
|
|
|
|
### Ocultamiento del menú
|
|
|
|
Use `hide-on-click` para definir si el menú se cierra al hacer clic.
|
|
|
|
:::demo El menú predeterminado se cerrará cuando haga clic en los elementos del menú, y se puede desactivar configurando `hide-on-click` como false.
|
|
|
|
```html
|
|
<el-dropdown :hide-on-click="false">
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item disabled>Action 4</el-dropdown-item>
|
|
<el-dropdown-item divided>Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<style>
|
|
.el-dropdown-link {
|
|
cursor: pointer;
|
|
color: #409EFF;
|
|
}
|
|
.el-icon-arrow-down {
|
|
font-size: 12px;
|
|
}
|
|
</style>
|
|
```
|
|
:::
|
|
|
|
### Evento command
|
|
|
|
Al hacer clic en cada elemento desplegable se detona un evento cuyo parámetro es asignado por cada elemento.
|
|
|
|
:::demo
|
|
```html
|
|
<el-dropdown @command="handleCommand">
|
|
<span class="el-dropdown-link">
|
|
Dropdown List<i class="el-icon-arrow-down el-icon--right"></i>
|
|
</span>
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item command="a">Action 1</el-dropdown-item>
|
|
<el-dropdown-item command="b">Action 2</el-dropdown-item>
|
|
<el-dropdown-item command="c">Action 3</el-dropdown-item>
|
|
<el-dropdown-item command="d" disabled>Action 4</el-dropdown-item>
|
|
<el-dropdown-item command="e" divided>Action 5</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<style>
|
|
.el-dropdown-link {
|
|
cursor: pointer;
|
|
color: #409EFF;
|
|
}
|
|
.el-icon-arrow-down {
|
|
font-size: 12px;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
export default {
|
|
methods: {
|
|
handleCommand(command) {
|
|
this.$message('click on item ' + command);
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
```
|
|
:::
|
|
|
|
### Tamaños
|
|
|
|
Además del tamaño predeterminado, el componente Dropdown proporciona tres tamaños adicionales para que pueda elegir entre diferentes escenarios
|
|
|
|
:::demo Utilice el atributo `size` para establecer tamaños adicionales con `medium`, `small` o `mini`.
|
|
|
|
```html
|
|
<el-dropdown split-button type="primary">
|
|
Default
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<el-dropdown size="medium" split-button type="primary">
|
|
Medium
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<el-dropdown size="small" split-button type="primary">
|
|
Small
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
|
|
<el-dropdown size="mini" split-button type="primary">
|
|
Mini
|
|
<template #dropdown>
|
|
<el-dropdown-menu>
|
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
|
<el-dropdown-item>Action 3</el-dropdown-item>
|
|
<el-dropdown-item>Action 4</el-dropdown-item>
|
|
</el-dropdown-menu>
|
|
</template>
|
|
</el-dropdown>
|
|
```
|
|
:::
|
|
|
|
|
|
### Dropdown atributos
|
|
| Atributo | Descripción | Tipo | Valores aceptados | Por defecto |
|
|
| ------------- | ---------------------------------------- | ------- | ---------------------------------------- | ----------- |
|
|
| type | tipo de botón de menú, consulte Componente`Button`, sólo funciona cuando `split-button` es true. | string | — | — |
|
|
| size | tamaño del menú, también funciona en `split-button` | string | medium / small / mini | — |
|
|
| split-button | si se visualiza un grupo de botones | boolean | — | false |
|
|
| placement | colocación del menú | string | top/top-start/top-end/bottom/bottom-start/bottom-end | bottom-end |
|
|
| trigger | cómo detonar | string | hover/click/contextmenu | hover |
|
|
| hide-on-click | si se oculta el menú después de hacer clic en el elemento | boolean | — | true |
|
|
| show-timeout | Tiempo de retardo antes de mostrar un dropdown (solamente trabaja cuando se dispara `hover`) | number | — | 250 |
|
|
| hide-timeout | Tiempo de retardo antes de ocultar un dropdown (solamente trabaja cuando se dispara `hover`) | number | — | 150 |
|
|
| tabindex | [tabindex](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/tabindex) de Dropdown | number | — | 0 |
|
|
|
|
### Dropdown Slots
|
|
|
|
| Nombre | Descripción |
|
|
|------|--------|
|
|
| — | contenido del Dropdown. Aviso: Debe ser un elemento html dom válido (ej. `<span>, <button>` etc.) o `el-component`, para adjuntar el listener trigger |
|
|
| dropdown | contenido del menu Dropdown, normalmente es un elemento `<el-dropdown-menu>` |
|
|
|
|
### Dropdown Eventos
|
|
| Nombre | Descripción | Parametros |
|
|
| -------------- | ---------------------------------------- | ---------------------------------------- |
|
|
| click | si `split-button` es `true`, se activa al hacer clic en el botón izquierdo | — |
|
|
| command | activa cuando se hace clic en un elemento desplegable | el comando enviado desde el elemento desplegable |
|
|
| visible-change | se activa cuando aparece/desaparece el desplegable | true cuando aparece, y false de otro modo |
|
|
|
|
### Dropdown Menu Item Atributos
|
|
| Atributo | Descripción | Tipo | Valores aceptados | Por defecto |
|
|
| -------- | ---------------------------------------- | -------------------- | ----------------- | ----------- |
|
|
| command | un comando que se enviará al `command` callback del Dropdown | string/number/object | — | — |
|
|
| disabled | si el elemento está desactivado | boolean | — | false |
|
|
| divided | si se visualiza un divisor | boolean | — | false |
|
|
| icon | nombre de la clase del icono | string | — | — |
|