element/examples/docs/es/loading.md

209 lines
6.8 KiB
Markdown
Raw Normal View History

2017-11-13 12:40:57 +08:00
## Cargando
2017-11-06 19:22:02 +08:00
2017-11-13 12:40:57 +08:00
Se muestra la animación mientras se cargan los datos.
2017-11-06 19:22:02 +08:00
2017-11-13 12:40:57 +08:00
### Cargando dentro de un contenedor
2017-11-06 19:22:02 +08:00
2017-11-13 12:40:57 +08:00
Muestra una animación en un contenedor (como en una tabla) mientras se cargan los datos.
2017-11-06 19:22:02 +08:00
2017-11-13 12:40:57 +08:00
:::demo Element provee dos maneras para invocar el componente de Cargando: por directiva y por servicio. Para la directiva personalizada `v-loading`, solo necesitas enlazarlo a un valor `Boolean`. Por defecto, la máscara de carga se agregará al elemento donde se usa la directiva. Al agregar el modificador `body`, la máscara se agrega al elemento body.
2017-11-06 19:22:02 +08:00
```html
<template>
<el-table
v-loading="loading"
:data="tableData"
style="width: 100%">
<el-table-column
prop="date"
2017-11-13 12:40:57 +08:00
label="Fecha"
2017-11-06 19:22:02 +08:00
width="180">
</el-table-column>
<el-table-column
prop="name"
2017-11-13 12:40:57 +08:00
label="Nombre"
2017-11-06 19:22:02 +08:00
width="180">
</el-table-column>
<el-table-column
prop="address"
2017-11-13 12:40:57 +08:00
label="Dirección">
2017-11-06 19:22:02 +08:00
</el-table-column>
</el-table>
</template>
<style>
body {
margin: 0;
}
</style>
<script>
export default {
data() {
return {
tableData: [{
date: '2016-05-02',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}, {
date: '2016-05-04',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}, {
date: '2016-05-01',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}],
loading: true
};
}
};
</script>
```
:::
2017-11-13 12:40:57 +08:00
### Personalización
2017-11-06 19:22:02 +08:00
2017-12-03 18:03:06 +08:00
Puede personalizar el texto de carga, spinner de carga y color de fondo.
2017-11-06 19:22:02 +08:00
2017-12-03 18:03:06 +08:00
:::demo Agrege el atributo `element-loading-text` al elemento en el que `v-loading` está vinculado, y su valor se mostrará debajo del spinner. Del mismo modo, `element-loading-spinner` y `element-loading-background` son para personalizar el nombre de la clase del spinner y el color de fondo.
2017-11-06 19:22:02 +08:00
```html
<template>
<el-table
2019-04-12 10:40:46 +08:00
v-loading="loading"
2017-11-06 19:22:02 +08:00
element-loading-text="Loading..."
element-loading-spinner="el-icon-loading"
element-loading-background="rgba(0, 0, 0, 0.8)"
:data="tableData"
style="width: 100%">
<el-table-column
prop="date"
2017-11-13 12:40:57 +08:00
label="Fecha"
2017-11-06 19:22:02 +08:00
width="180">
</el-table-column>
<el-table-column
prop="name"
2017-11-13 12:40:57 +08:00
label="Nombre"
2017-11-06 19:22:02 +08:00
width="180">
</el-table-column>
<el-table-column
prop="address"
2017-11-13 12:40:57 +08:00
label="Dirección">
2017-11-06 19:22:02 +08:00
</el-table-column>
</el-table>
</template>
<script>
export default {
data() {
return {
tableData: [{
date: '2016-05-02',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}, {
date: '2016-05-04',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}, {
date: '2016-05-01',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District'
}],
2019-04-12 10:40:46 +08:00
loading: true
2017-11-06 19:22:02 +08:00
};
}
};
</script>
```
:::
2017-11-13 12:40:57 +08:00
### Cargando a pantalla completa
2017-11-06 19:22:02 +08:00
2017-11-13 12:40:57 +08:00
Muestra una animación de pantalla completa mientras se cargan los datos
2017-11-06 19:22:02 +08:00
2017-12-03 18:03:06 +08:00
:::demo Cuando se utiliza como una directiva, la carga a pantalla completa requiere el modificador `fullscreen`, y este puede ser agregado al `body`. En este caso, si desea deshabilitar el desplazamiento en `body`, puede agregar otro modificador `lock`. Cuando se utiliza como un servicio, el componente puede ser mostrado a pantalla completa por defecto.
2017-11-06 19:22:02 +08:00
```html
<template>
<el-button
type="primary"
@click="openFullScreen"
v-loading.fullscreen.lock="fullscreenLoading">
2017-11-13 12:42:42 +08:00
Como directiva
2017-11-06 19:22:02 +08:00
</el-button>
<el-button
type="primary"
2019-04-12 10:40:46 +08:00
@click="openFullScreen">
2017-11-13 12:42:42 +08:00
Como servicio
2017-11-06 19:22:02 +08:00
</el-button>
</template>
<script>
export default {
data() {
return {
fullscreenLoading: false
}
},
methods: {
openFullScreen() {
this.fullscreenLoading = true;
setTimeout(() => {
this.fullscreenLoading = false;
}, 2000);
},
2019-04-12 10:40:46 +08:00
openFullScreen() {
2017-11-06 19:22:02 +08:00
const loading = this.$loading({
lock: true,
text: 'Loading',
spinner: 'el-icon-loading',
background: 'rgba(0, 0, 0, 0.7)'
});
setTimeout(() => {
loading.close();
}, 2000);
}
}
}
</script>
```
:::
2017-11-13 12:40:57 +08:00
### Servicio
2017-12-03 18:03:06 +08:00
Puede invocar el componente con un servicio. Importe el servicio:
2017-11-13 12:40:57 +08:00
2017-11-06 19:22:02 +08:00
```javascript
import { Loading } from 'element-ui';
```
2017-11-13 12:40:57 +08:00
Invocar:
2017-11-06 19:22:02 +08:00
```javascript
Loading.service(options);
```
2017-12-03 18:03:06 +08:00
El parámetro `options` es la configuración del componente, y estos detalles pueden ser encontrados en la siguiente table. `LoadingService` devuelve una instancia del componente, y puede cerrarlo invocando el método `close`:
2017-11-06 19:22:02 +08:00
```javascript
let loadingInstance = Loading.service(options);
loadingInstance.close();
```
2017-11-13 12:40:57 +08:00
Tenga en cuenta que, en este caso, el componente a pantalla completa es una instancia única. Si un nuevo componente de pantalla completa es invocado antes de que se cierre la existente, se devolverá la instancia existente en lugar de crear la otra instancia:
2017-11-06 19:22:02 +08:00
```javascript
let loadingInstance1 = Loading.service({ fullscreen: true });
let loadingInstance2 = Loading.service({ fullscreen: true });
console.log(loadingInstance1 === loadingInstance2); // true
```
2017-11-13 12:40:57 +08:00
Llamar al método `close` en cualquiera de estas puede cerrarlo.
2017-11-06 19:22:02 +08:00
2017-12-03 18:03:06 +08:00
Si Element es importado completamente, un método global `$loading` puede ser registrado a Vue.prototype. Puede invocarlo como esto: `this.$loading(options)`, y también devuelve una instancia del componente.
2017-11-06 19:22:02 +08:00
### Options
2017-12-03 18:03:06 +08:00
| Atributo | Descripción | Tipo | Valores aceptados | Por defecto |
| ----------- | ---------------------------------------- | ------------- | ----------------- | ------------- |
| target | el nodo del DOM que el componente debe cubrir. Acepta un objecto DOM o una cadena. Si está es una cadena, este será pasado a `document.querySelector` para obtener el correspondiente nodo del DOM | object/string | — | document.body |
| body | igual que el modificador `body` de `v-loading` | boolean | — | false |
| fullscreen | igual que el modificador `fullscreen` de `v-loading` | boolean | — | true |
| lock | igual que el modificador `lock` de `v-loading` | boolean | — | false |
| text | texto de cargando que se muestra debajo del spinner | string | — | — |
| spinner | nombre de clase del spinner personalizado | string | — | — |
| background | color de fondo de la máscara | string | — | — |
| customClass | nombre de clase personalizada para el componente | string | — | — |