2017-11-06 19:22:02 +08:00
< script >
const cityOptions = ['Shanghai', 'Beijing', 'Guangzhou', 'Shenzhen'];
module.exports = {
data() {
return {
2017-11-09 00:29:51 +08:00
checkList: ['seleccionado y deshabilitado','Opción A'],
// checkList2: ['Opción A'],
2017-11-06 19:22:02 +08:00
checked: true,
checked1: false,
checked2: true,
checked3: true,
checked4: false,
checked5: false,
checked6: true,
isValid: 'valid',
checkAll: false,
cities: cityOptions,
checkedCities: ['Shanghai', 'Beijing'],
checkedCities1: ['Shanghai', 'Beijing'],
isIndeterminate: true,
checkboxGroup1: ['Shanghai'],
checkboxGroup2: ['Shanghai'],
checkboxGroup3: ['Shanghai'],
checkboxGroup4: ['Shanghai'],
checkboxGroup5: [],
checkboxGroup6: []
};
},
methods: {
handleChange(ev) {
console.log(ev);
},
handleCheckAllChange(val) {
this.checkedCities = val ? cityOptions : [];
this.isIndeterminate = false;
},
handleCheckedCitiesChange(value) {
let checkedCount = value.length;
this.checkAll = checkedCount === this.cities.length;
this.isIndeterminate = checkedCount > 0 & & checkedCount < this.cities.length ;
}
}
};
< / script >
## Checkbox
2017-11-09 00:29:51 +08:00
Un grupo de opciones para manejar múltiples elecciones.
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
### Uso básico
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
Checkbox puede ser usado para alternar entre dos estados.
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
:::demo Define `v-model` (enlaza la variable) en `el-checkbox` . El valor por defecto es un `Boolean` para un `checkbox` , y se convierte en `true` cuando este es seleccionado. El contenido dentro del tag `el-checkbox` se convierte en la descripción al costado del botón del checkbox.
2017-11-06 19:22:02 +08:00
```html
< template >
2017-11-09 00:29:51 +08:00
<!-- `checked` debe ser true o false -->
< el-checkbox v-model = "checked" > Opción< / el-checkbox >
2017-11-06 19:22:02 +08:00
< / template >
< script >
export default {
data() {
return {
checked: true
};
}
};
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Estado Deshabilitado
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
Estado deshabilitado para el checkbox.
2017-11-06 19:22:02 +08:00
2017-12-12 12:45:09 +08:00
:::demo Setear el atributo `disabled` .
2017-11-06 19:22:02 +08:00
```html
< template >
2017-11-09 00:29:51 +08:00
< el-checkbox v-model = "checked1" disabled > Opción< / el-checkbox >
< el-checkbox v-model = "checked2" disabled > Opción< / el-checkbox >
2017-11-06 19:22:02 +08:00
< / template >
< script >
export default {
data() {
return {
checked1: false,
checked2: true
};
}
};
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Grupo de Checkboxes
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
Es usado por multiples checkboxes los cuales están enlazados a un grupo, indica si una opción está seleccionada verificando si esta está marcada.
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
:::demo El elemento `checkbox-group` puede manejar multiples checkboxes en un grupo usando `v-model` el cuál está enlazado a un `Array` . Dentro del elemento `el-checkbox` , `label` es el valor del checkbox. Si en ese tag no hay contenido anidado, `label` va a ser mostrado como la descripción al lado del botón del checkbox. `label` también se corresponde con los valores del array. Es seleccionado si el valor especificado existe en el array y viceversa.
2017-11-06 19:22:02 +08:00
```html
< template >
< el-checkbox-group v-model = "checkList" >
2017-11-09 00:29:51 +08:00
< el-checkbox label = "Opción A" > < / el-checkbox >
< el-checkbox label = "Opción B" > < / el-checkbox >
< el-checkbox label = "Opción C" > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< el-checkbox label = "disabled" disabled > < / el-checkbox >
2017-11-09 00:29:51 +08:00
< el-checkbox label = "Seleccionado y deshabilitado" disabled > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< / el-checkbox-group >
< / template >
< script >
export default {
data () {
return {
2017-11-09 00:29:51 +08:00
checkList: ['Seleccionado y deshabilitado','Opción A']
2017-11-06 19:22:02 +08:00
};
}
};
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Indeterminado
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
La propiedad `indeterminate` puede ser usada para generar el efecto de marcar todos (check all).
2017-11-06 19:22:02 +08:00
:::demo
```html
< template >
2017-11-09 00:29:51 +08:00
< el-checkbox :indeterminate = "isIndeterminate" v-model = "checkAll" @change =" handleCheckAllChange " > Marcar todos</ el-checkbox >
2017-11-06 19:22:02 +08:00
< div style = "margin: 15px 0;" > < / div >
< el-checkbox-group v-model = "checkedCities" @change =" handleCheckedCitiesChange " >
< el-checkbox v-for = "city in cities" :label = "city" :key = "city" > {{city}}< / el-checkbox >
< / el-checkbox-group >
< / template >
< script >
const cityOptions = ['Shanghai', 'Beijing', 'Guangzhou', 'Shenzhen'];
export default {
data() {
return {
checkAll: false,
checkedCities: ['Shanghai', 'Beijing'],
cities: cityOptions,
isIndeterminate: true
};
},
methods: {
handleCheckAllChange(val) {
this.checkedCities = val ? cityOptions : [];
this.isIndeterminate = false;
},
handleCheckedCitiesChange(value) {
let checkedCount = value.length;
this.checkAll = checkedCount === this.cities.length;
this.isIndeterminate = checkedCount > 0 & & checkedCount < this.cities.length ;
}
}
};
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Cantidad Mínima / Máxima de elementos seleccionados
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
Las propiedades `min` y `max` pueden limitar la cantidad de elementos seleccionados.
2017-11-06 19:22:02 +08:00
:::demo
```html
< template >
< el-checkbox-group
v-model="checkedCities1"
:min="1"
:max="2">
< el-checkbox v-for = "city in cities" :label = "city" :key = "city" > {{city}}< / el-checkbox >
< / el-checkbox-group >
< / template >
< script >
const cityOptions = ['Shanghai', 'Beijing', 'Guangzhou', 'Shenzhen'];
export default {
data() {
return {
checkedCities1: ['Shanghai', 'Beijing'],
cities: cityOptions
};
}
};
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Estilo tipo Botón
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
Checkbox con estilo tipo Botón.
2017-11-06 19:22:02 +08:00
2017-12-03 18:03:06 +08:00
:::demo Sólo debe cambiar el elemento `el-checkbox` por el elemento `el-checkbox-button` . También proveemos el atributo `size` .
2017-11-06 19:22:02 +08:00
```html
< template >
< div >
< el-checkbox-group v-model = "checkboxGroup1" >
< el-checkbox-button v-for = "city in cities" :label = "city" :key = "city" > {{city}}< / el-checkbox-button >
< / el-checkbox-group >
< / div >
< div style = "margin-top: 20px" >
< el-checkbox-group v-model = "checkboxGroup2" size = "medium" >
< el-checkbox-button v-for = "city in cities" :label = "city" :key = "city" > {{city}}< / el-checkbox-button >
< / el-checkbox-group >
< / div >
< div style = "margin-top: 20px" >
< el-checkbox-group v-model = "checkboxGroup3" size = "small" >
< el-checkbox-button v-for = "city in cities" :label = "city" :disabled = "city === 'Beijing'" :key = "city" > {{city}}< / el-checkbox-button >
< / el-checkbox-group >
< / div >
< div style = "margin-top: 20px" >
< el-checkbox-group v-model = "checkboxGroup4" size = "mini" disabled >
< el-checkbox-button v-for = "city in cities" :label = "city" :key = "city" > {{city}}< / el-checkbox-button >
< / el-checkbox-group >
< / div >
< / template >
< script >
const cityOptions = ['Shanghai', 'Beijing', 'Guangzhou', 'Shenzhen'];
export default {
data () {
return {
checkboxGroup1: ['Shanghai'],
checkboxGroup2: ['Shanghai'],
checkboxGroup3: ['Shanghai'],
checkboxGroup4: ['Shanghai'],
cities: cityOptions
};
}
}
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Con bordes
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
:::demo El atributo `border` agrega un borde a los Checkboxes.
2017-11-06 19:22:02 +08:00
```html
< template >
< div >
2017-11-09 00:29:51 +08:00
< el-checkbox v-model = "checked3" label = "Opción1" border > < / el-checkbox >
< el-checkbox v-model = "checked4" label = "Opción2" border > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< / div >
< div style = "margin-top: 20px" >
2017-11-09 00:29:51 +08:00
< el-checkbox v-model = "checked5" label = "Opción1" border size = "medium" > < / el-checkbox >
< el-checkbox v-model = "checked6" label = "Opción2" border size = "medium" > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< / div >
< div style = "margin-top: 20px" >
< el-checkbox-group v-model = "checkboxGroup5" size = "small" >
2017-11-09 00:29:51 +08:00
< el-checkbox label = "Opción1" border > < / el-checkbox >
< el-checkbox label = "Opción2" border disabled > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< / el-checkbox-group >
< / div >
< div style = "margin-top: 20px" >
< el-checkbox-group v-model = "checkboxGroup6" size = "mini" disabled >
2017-11-09 00:29:51 +08:00
< el-checkbox label = "Opción1" border > < / el-checkbox >
< el-checkbox label = "Opción2" border > < / el-checkbox >
2017-11-06 19:22:02 +08:00
< / el-checkbox-group >
< / div >
< / template >
< script >
export default {
data () {
return {
checked3: true,
checked4: false,
checked5: false,
checked6: true,
checkboxGroup5: [],
checkboxGroup6: []
};
}
}
< / script >
```
:::
2017-11-09 00:29:51 +08:00
### Atributos de Checkbox
2017-12-03 18:03:06 +08:00
| Atributo | Descripción | Tipo | Valores aceptados | Por defecto |
| ------------- | ---------------------------------------- | ------------------------- | --------------------- | ----------- |
| label | valor del Checkbox si es usado dentro de un tag `checkbox-group` | string / number / boolean | — | — |
| true-label | valor del Checkbox si está marcado | string / number | — | — |
| false-label | valor del Checkbox si no está marcado | string / number | — | — |
| disabled | especifica si el Checkbox está deshabilitado | boolean | — | false |
| border | especifica si agrega un borde alrededor del Checkbox | boolean | — | false |
| size | tamaño del Checkbox, sólo funciona si `border` es true | string | medium / small / mini | — |
| name | atributo 'name' nativo | string | — | — |
| checked | especifica si el Checkbox está marcado | boolean | — | false |
| indeterminate | similar a `indeterminate` en el checkbox nativo | boolean | — | false |
2017-11-09 00:29:51 +08:00
### Eventos de Checkbox
2017-12-03 18:03:06 +08:00
| Nombre | Descripción | Parametros |
| ------ | ---------------------------------------- | -------------------- |
| change | se ejecuta cuando el valor enlazado cambia | el valor actualizado |
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
### Atributos de Checkbox-group
2017-12-03 18:03:06 +08:00
| Atributo | Descripción | Tipo | Valores aceptados | Por Defecto |
| ---------- | ---------------------------------------- | ------- | --------------------- | ----------- |
| size | tamaño de los checkboxes de tipo botón o los checkboxes con border | string | medium / small / mini | — |
| disabled | especifica si los checkboxes anidados están deshabilitados | boolean | — | false |
| min | cantidad mínima de checkboxes que deben ser marcados | number | — | — |
| max | cantidad máxima de checkboxes que pueden ser marcados | number | — | — |
| text-color | color de fuente cuando el botón está activo | string | — | #ffffff |
| fill | color de border y de fondo cuando el botón está activo | string | — | #409EFF |
2017-11-09 00:29:51 +08:00
### Eventos de Checkbox-group
2017-12-03 18:03:06 +08:00
| Nombre de Evento | Descripción | Parametros |
| ---------------- | ---------------------------------------- | -------------------- |
| change | se ejecuta cuando el valor enlazado cambia | el valor actualizado |
2017-11-06 19:22:02 +08:00
2017-11-09 00:29:51 +08:00
### Atributos de Checkbox-button
2017-12-03 18:03:06 +08:00
| Atributo | Descripción | Tipo | Valores aceptados | Por defecto |
| ----------- | ---------------------------------------- | ------------------------- | ----------------- | ----------- |
| label | valor del checkbox cuando es usado dentro de un `checkbox-group` | string / number / boolean | — | — |
| true-label | valor del checkbox si este está marcado | string / number | — | — |
| false-label | valor del checkbox si este no está marcado | string / number | — | — |
| disabled | especifica si el checkbox está deshabilitado | boolean | — | false |
| name | atributo 'name' del checbox nativo | string | — | — |
| checked | si el checkbox está marcado | boolean | — | false |