mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-12 10:45:10 +08:00
d7c7e86955
Co-authored-by: 无星 <32910694@qq.com>
589 lines
23 KiB
Markdown
589 lines
23 KiB
Markdown
## MessageBox
|
||
|
||
Un conjunto de cajas modales simulando un sistema de message box, principalmente para alertar información, confirmar operaciones y mostrar mensajes de aviso.
|
||
:::tip
|
||
Por diseño los message box nos proveen de simulaciones de sistemas como los componentes `alert`, `confirm` y `prompt`,entonces su contenido debería ser simple. para contenido mas complejo, por favor utilice el componente Dialog.
|
||
:::
|
||
|
||
### Alert
|
||
|
||
Alert interrumpe las operaciones realizadas hasta que el usuario confirme la alerta.
|
||
|
||
:::demo Desplegar una alerta utilizando el método `$alert`. Simula el sistema `alert`, y no puede ser cerrado al presionar la tecla ESC o al dar clic fuera de la caja. En este ejemplo, dos parámetros son recibidos `message` y `title`. Vale la pena mencionar que cuando la caja es cerrada, regresa un objeto `Promise` para su procesamiento posteriormente. Si no estas seguro si el navegador soporta `Promise`, deberías importar una librería de terceros de polyfill o utilizar callbacks.
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open the Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$alert('This is a message', 'Title', {
|
||
confirmButtonText: 'OK',
|
||
callback: action => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: `action: ${ action }`
|
||
});
|
||
}
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
const open = () => {
|
||
ElMessageBox.alert('This is a message', 'Title', {
|
||
confirmButtonText: 'OK',
|
||
callback: (action) => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: `action: ${action}`,
|
||
});
|
||
},
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
### Confirm
|
||
|
||
Confirm es utilizado para preguntar al usuario y recibir una confirmación.
|
||
|
||
|
||
:::demo Llamando al método `$confirm` para abrir el componente confirm, y simula el sistema `confirm`. También podemos personalizar a gran medida el componente Message Box al mandar un tercer atributo llamado `options` que es literalmente un objeto. El atributo `type` indica el tipo de mensaje, y su valor puede ser `success`, `error`, `info` y `warning`. Se debe tener en cuenta que el segundo atributo `title` debe ser de tipo `string`, y si es de tipo `object`, sera manejado como el atributo `options`. Aquí utilizamos `Promise` para manejar posteriormente el proceso.
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open the Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$confirm('This will permanently delete the file. Continue?', 'Warning', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
type: 'warning'
|
||
}).then(() => {
|
||
this.$message({
|
||
type: 'success',
|
||
message: 'Delete completed'
|
||
});
|
||
}).catch(() => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: 'Delete canceled'
|
||
});
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
import { ElMessage } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
|
||
const open = () => {
|
||
ElMessageBox.confirm('proxy will permanently delete the file. Continue?', 'Warning', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
type: 'warning',
|
||
}).then(() => {
|
||
ElMessage({
|
||
type: 'success',
|
||
message: 'Delete completed',
|
||
});
|
||
}).catch(() => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: 'Delete canceled',
|
||
});
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
|
||
:::
|
||
|
||
### Prompt
|
||
|
||
Prompt es utilizado cuando se requiere entrada de información del usuario.
|
||
|
||
:::demo Llamando al método `$prompt` desplegamos el componente prompt, y simula el sistema `prompt`.Puedes utilizar el parámetro `inputPattern` para especificar tu propio patrón RegExp. Utiliza el parámetro `inputValidator` para especificar el método de validación, y debería regresar un valor de tipo `Boolean` o `String`. Al regresar `false` o `String` significa que la validación a fallado, y la cadena regresada se usara como `inputErrorMessage`. Ademas, puedes personalizar el atributo placeholder del input box con el parámetro `inputPlaceholder`.
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$prompt('Please input your e-mail', 'Tip', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
inputPattern: /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/,
|
||
inputErrorMessage: 'Invalid Email'
|
||
}).then(({ value }) => {
|
||
this.$message({
|
||
type: 'success',
|
||
message: 'Your email is:' + value
|
||
});
|
||
}).catch(() => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: 'Input canceled'
|
||
});
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
import { ElMessage } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
const open = () => {
|
||
ElMessageBox.prompt('Please input your e-mail', 'Tip', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
inputPattern: /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/,
|
||
inputErrorMessage: 'Invalid Email',
|
||
})
|
||
.then(({ value }) => {
|
||
ElMessage({
|
||
type: 'success',
|
||
message: `Your email is:${value}`,
|
||
});
|
||
})
|
||
.catch(() => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: 'Input canceled',
|
||
});
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
### Personalización
|
||
|
||
Puede ser personalizado para mostrar diversos contenidos.
|
||
|
||
:::demo Los tres métodos mencionados anteriormente son un rempaquetado del método `$msgbox`. En este ejemplo se realiza una llamada al método `$msgbox` directamente utilizando el atributo `showCancelButton`, el cual es utilizado para indicar si el botón cancelar es mostrado en pantalla. Además podemos utilizar el atributo `cancelButtonClass` para agregar un estilo personalizado y el atributo `cancelButtonText` para personalizar el texto del botón (el botón de confirmación también cuenta con estos campos, y podrá encontrar una lista completa de estos atributos al final de esta documentación). Este ejemplo también utiliza el atributo `beforeClose`. Es un método que es disparado cuando una instancia del componente MessageBox es cerrada, y su ejecución detendrá el cierre de la instancia. Tiene tres parámetros: `action`, `instance` y `done`. Al utilizarla te permite manipular la instancia antes de que sea cerrada, e.g. activando `loading` para el botón de confirmación; puede invocar el método `done` para cerrar la instancia del componente MessageBox (si el método `done` no es llamado dentro del atributo `beforeClose`, la instancia no podrá cerrarse).
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
import { h } from 'vue';
|
||
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$msgbox({
|
||
title: 'Message',
|
||
message: h('p', null, [
|
||
h('span', null, 'Message can be '),
|
||
h('i', { style: 'color: teal' }, 'VNode')
|
||
]),
|
||
showCancelButton: true,
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
beforeClose: (action, instance, done) => {
|
||
if (action === 'confirm') {
|
||
instance.confirmButtonLoading = true;
|
||
instance.confirmButtonText = 'Loading...';
|
||
setTimeout(() => {
|
||
done();
|
||
setTimeout(() => {
|
||
instance.confirmButtonLoading = false;
|
||
}, 300);
|
||
}, 3000);
|
||
} else {
|
||
done();
|
||
}
|
||
}
|
||
}).then(action => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: 'action: ' + action
|
||
});
|
||
});
|
||
},
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent, h } from 'vue';
|
||
import { ElMessage } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
|
||
const open = () => {
|
||
ElMessageBox({
|
||
title: 'Message',
|
||
message: h('p', null, [
|
||
h('span', null, 'Message can be '),
|
||
h('i', { style: 'color: teal' }, 'VNode'),
|
||
]),
|
||
showCancelButton: true,
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
beforeClose: (action, instance, done) => {
|
||
if (action === 'confirm') {
|
||
instance.confirmButtonLoading = true;
|
||
instance.confirmButtonText = 'Loading...';
|
||
setTimeout(() => {
|
||
done();
|
||
setTimeout(() => {
|
||
instance.confirmButtonLoading = false;
|
||
}, 300);
|
||
}, 3000);
|
||
} else {
|
||
done();
|
||
}
|
||
},
|
||
}).then((action) => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: `action: ${action}`,
|
||
});
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
:::tip
|
||
|
||
El contenido de MessageBox puede ser `VNode`, permitiéndonos pasar componentes personalizados. Al abrir el MessageBox, Vue compara el nuevo `VNode` con el viejo `VNode`, y luego averigua cómo actualizar eficientemente la interfaz de usuario, de modo que es posible que los componentes no se vuelvan a procesar completamente ([#8931](https://github.com/ElemeFE/element/issues/8931)). En este caso, se puede añadir una clave única a `VNode` cada vez que se abre MessageBox: [ejemplo](https://jsfiddle.net/zhiyang/ezmhq2ef).
|
||
|
||
:::
|
||
|
||
### Utiliza cadenas HTML
|
||
|
||
`message` soporta cadenas HTML.
|
||
|
||
:::demo Establezca el valor de `dangerouslyUseHTMLString` a true y `message` sera tratado como una cadena HTML.
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$alert('<strong>This is <i>HTML</i> string</strong>', 'HTML String', {
|
||
dangerouslyUseHTMLString: true
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
const open = () => {
|
||
ElMessageBox.alert('<strong>proxy is <i>HTML</i> string</strong>', 'HTML String', {
|
||
dangerouslyUseHTMLString: true,
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
:::warning
|
||
Aunque la propiedad `message` soporta cadenas HTML, realizar arbitrariamente render dinámico de HTML en nuestro sitio web puede ser muy peligroso ya que puede conducir fácilmente a [XSS attacks](https://en.wikipedia.org/wiki/Cross-site_scripting). Entonces cuando `dangerouslyUseHTMLString` esta activada, asegúrese que el contenido de `message` sea de confianza, y **nunca** asignar `message` a contenido generado por el usuario.
|
||
:::
|
||
|
||
### Distinguir entre cancelar y cerrar
|
||
|
||
En algunos casos, hacer clic en el botón Cancelar y en el botón Cerrar puede tener diferentes significados.
|
||
|
||
:::demo Por defecto, los parámetros de `Promise's reject callback` y `callback` son `cancel` cuando el usuario cancela (haciendo clic en el botón de cancelación) y cierra (haciendo clic en el botón de cerrar o en la capa de máscara, pulsando la tecla ESC) el MessageBox. Si `distinguishCancelAndClose` está ajustado a `true`, los parámetros de las dos operaciones anteriores son `cancel` y `close` respectivamente.
|
||
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$confirm('You have unsaved changes, save and proceed?', 'Confirm', {
|
||
distinguishCancelAndClose: true,
|
||
confirmButtonText: 'Save',
|
||
cancelButtonText: 'Discard Changes'
|
||
})
|
||
.then(() => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: 'Changes saved. Proceeding to a new route.'
|
||
});
|
||
})
|
||
.catch(action => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: action === 'cancel'
|
||
? 'Changes discarded. Proceeding to a new route.'
|
||
: 'Stay in the current route'
|
||
})
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
import { ElMessage } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
const open = () => {
|
||
ElMessageBox.confirm('You have unsaved changes, save and proceed?', 'Confirm', {
|
||
distinguishCancelAndClose: true,
|
||
confirmButtonText: 'Save',
|
||
cancelButtonText: 'Discard Changes',
|
||
})
|
||
.then(() => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: 'Changes saved. Proceeding to a new route.',
|
||
});
|
||
})
|
||
.catch((action) => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: action === 'cancel'
|
||
? 'Changes discarded. Proceeding to a new route.'
|
||
: 'Stay in the current route',
|
||
});
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
### Contenido centrado
|
||
El contenido del componente MessageBox puede ser centrado.
|
||
|
||
:::demo Establecer `center` a `true` centrara el contenido
|
||
|
||
```html
|
||
<template>
|
||
<el-button type="text" @click="open">Click to open Message Box</el-button>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
methods: {
|
||
open() {
|
||
this.$confirm('This will permanently delete the file. Continue?', 'Warning', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
type: 'warning',
|
||
center: true
|
||
}).then(() => {
|
||
this.$message({
|
||
type: 'success',
|
||
message: 'Delete completed'
|
||
});
|
||
}).catch(() => {
|
||
this.$message({
|
||
type: 'info',
|
||
message: 'Delete canceled'
|
||
});
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
<!--
|
||
<setup>
|
||
|
||
import { defineComponent } from 'vue';
|
||
import { ElMessageBox } from 'element-plus';
|
||
import { ElMessage } from 'element-plus';
|
||
|
||
export default defineComponent({
|
||
setup() {
|
||
|
||
const open = () => {
|
||
ElMessageBox.confirm('proxy will permanently delete the file. Continue?', 'Warning', {
|
||
confirmButtonText: 'OK',
|
||
cancelButtonText: 'Cancel',
|
||
type: 'warning',
|
||
center: true,
|
||
}).then(() => {
|
||
ElMessage({
|
||
type: 'success',
|
||
message: 'Delete completed',
|
||
});
|
||
}).catch(() => {
|
||
ElMessage({
|
||
type: 'info',
|
||
message: 'Delete canceled',
|
||
});
|
||
});
|
||
};
|
||
|
||
return {
|
||
open,
|
||
};
|
||
},
|
||
});
|
||
|
||
</setup>
|
||
-->
|
||
```
|
||
:::
|
||
|
||
### Métodos Globales
|
||
|
||
Si Element Plus fue importado completamente, agregara los siguientes métodos globales para `app.config.globalProperties`: `$msgbox`, `$alert`, `$confirm` y `$prompt`. Así que en una instancia de Vue puedes llamar el método `MessageBox` como lo que hicimos en esta pagina. Los parámetros son:
|
||
- `$msgbox(options)`
|
||
- `$alert(message, title, options)` or `$alert(message, options)`
|
||
- `$confirm(message, title, options)` or `$confirm(message, options)`
|
||
- `$prompt(message, title, options)` or `$prompt(message, options)`
|
||
|
||
### Importación local
|
||
|
||
Si prefieres importar `MessageBox` cuando lo necesites (on demand):
|
||
|
||
```javascript
|
||
import { ElMessageBox } from 'element-plus';
|
||
```
|
||
|
||
Los métodos correspondientes: `ElMessageBox`, `ElMessageBox.alert`, `ElMessageBox.confirm` y `ElMessageBox.prompt`. Los parámetros son los mismos que los anteriores.
|
||
|
||
### Opciones
|
||
|
||
| Atributo | Descripción | Tipo | Valores Permitidos | Por defecto |
|
||
| ------------------------ | ---------------------------------------- | ---------------------------------------- | -------------------------------- | ---------------------------------------- |
|
||
| title | titulo del componente MessageBox | string | — | — |
|
||
| message | contenido del componente MessageBox | string | — | — |
|
||
| dangerouslyUseHTMLString | utilizado para que `message` sea tratado como una cadena HTML | boolean | — | false |
|
||
| type | tipo de mensaje , utilizado para mostrar el icono | string | success / info / warning / error | — |
|
||
| iconClass | clase personalizada para el icono, sobreescribe `type` | string | — | — |
|
||
| customClass | nombre de la clase personalizada para el componente MessageBox | string | — | — |
|
||
| callback | MessageBox callback al cerrar si no desea utilizar Promise | function(action), donde la accion puede ser 'confirm', 'cancel' o 'close', e `instance` es la instancia del componente MessageBox. Puedes acceder a los metodos y atributos de esa instancia | — | — |
|
||
| beforeClose | callback llamado antes de cerrar el componente MessageBox, y previene que el componente MessageBox se cierre | function(action, instance, done), donde `action` pueden ser 'confirm', 'cancel' o 'close'; `instance` es la instancia del componente MessageBox, Puedes acceder a los metodos y atributos de esa instancia; `done` es para cerrar la instancia | — | — |
|
||
| distinguishCancelAndClose | si se debe distinguir entre cancelar y cerrar | boolean | — | false |
|
||
| lockScroll | utilizado para bloquear el desplazamiento del contenido del MessageBox prompts | boolean | — | true |
|
||
| showCancelButton | utilizado para mostrar un botón cancelar | boolean | — | false (true cuando es llamado con confirm y prompt) |
|
||
| showConfirmButton | utilizado para mostrar un botón confirmar | boolean | — | true |
|
||
| cancelButtonText | contenido de texto del botón cancelar | string | — | Cancel |
|
||
| confirmButtonText | contenido de texto del botón confirmar | string | — | OK |
|
||
| cancelButtonClass | nombre de la clase personalizada del botón cancelar | string | — | — |
|
||
| confirmButtonClass | nombre de la clase personalizada del botón confirmar | string | — | — |
|
||
| closeOnClickModal | utilizado para que que el componente MessageBox pueda ser cerrado al dar clic en la mascara | boolean | — | true (false cuando es llamado con alert) |
|
||
| closeOnPressEscape | utilizado para que que el componente MessageBox pueda ser cerrado al presionar la tecla ESC | boolean | — | true (false cuando es llamado con alert) |
|
||
| closeOnHashChange | utilizado para cerra el componente MessageBox cuando hash cambie | boolean | — | true |
|
||
| showInput | utilizado para mostrar el componente input | boolean | — | false (true cuando es llamado con prompt) |
|
||
| inputPlaceholder | placeholder para el componente input | string | — | — |
|
||
| inputType | tipo del componente input | string | — | text |
|
||
| inputValue | valor inicial del componente input | string | — | — |
|
||
| inputPattern | regexp del componente input | regexp | — | — |
|
||
| inputValidator | función de validación del componente input. Debe regresar un valor de tipo boolean o string. Si regresa un valor tipo string, sera asignado a inputErrorMessage | function | — | — |
|
||
| inputErrorMessage | mensaje de error cuando la validación falla | string | — | Illegal input |
|
||
| center | utilizado para alinear el contenido al centro | boolean | — | false |
|
||
| roundButton | utilizado para redondear el botón | boolean | — | false |
|
||
| buttonSize | custom size of confirm and cancel buttons | string | mini / small / medium / large | small |
|