Código de JavaScript - Mostrar un lista de checkbox al pulsar sobre un select

Versión 1.0
estrellaestrellaestrellaestrellaestrella(2)

Publicado el 12 de Julio del 2018gráfica de visualizaciones de la versión: Versión 1.0
15.873 visualizaciones desde el 12 de Julio del 2018
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
 
    <style>
    .multiselect {
        width: 200px;
        position:relative;
    }
 
    .selectBox {
        position: relative;
    }
 
    .selectBox select {
        width: 100%;
    }
 
    .overSelect {
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
    }
 
    #checkboxes {
        display: block;
        border: 1px #dadada solid;
        position:absolute;
        width:100%;
        background-color:white;
        box-sizing: border-box;
        overflow-y:auto;
        max-height:110px;
    }
    #checkboxes.hide {display:none;}
 
    #checkboxes label {
        display: block;
    }
 
    #checkboxes label:hover {
        background-color: #1e90ff;
    }
    </style>
</head>
 
<body>
 
<!-- https://stackoverflow.com/questions/17714705/how-to-use-checkbox-inside-select-option -->
 
<form>
    <div class="multiselect">
        <div class="selectBox" onclick="showCheckboxes()">
            <select>
                <option>Selecciona una opcion</option>
            </select>
            <div class="overSelect"></div>
        </div>
        <div id="checkboxes" class="hide">
            <label for="c1"><input type="checkbox" id="c1" />Primer checkbox</label>
            <label for="c2"><input type="checkbox" id="c2" />Segundo checkbox</label>
            <label for="c3"><input type="checkbox" id="c3" />Tercero checkbox</label>
            <label for="c4"><input type="checkbox" id="c4" />Quarto checkbox</label>
            <label for="c5"><input type="checkbox" id="c5" />Quinto checkbox</label>
            <label for="c6"><input type="checkbox" id="c6" />Sexto checkbox</label>
            <label for="c7"><input type="checkbox" id="c7" />Septimo checkbox</label>
            <label for="c8"><input type="checkbox" id="c8" />Octavo checkbox</label>
            <label for="c9"><input type="checkbox" id="c9" />Noveno checkbox</label>
            <label for="c10"><input type="checkbox" id="c10" />Decimo checkbox</label>
        </div>
    </div>
    hola
</form>
 
<script>
function showCheckboxes() {
    var checkboxes = document.getElementById("checkboxes");
    if(checkboxes.classList.contains("hide")) {
        checkboxes.classList.remove("hide");
    } else {
        checkboxes.classList.add("hide");
    }
}
</script>
 
</body>
</html>



Comentarios sobre la versión: Versión 1.0 (2)

Imágen de perfil
13 de Julio del 2018
estrellaestrellaestrellaestrellaestrella
Eres grande xve.
Veo que corregiste los pixeles de los bordes, pequeños detalles que marcan la diferencia.
Le agregue estas propiedades.
1
2
3
4
5
#checkboxes {
	...
	min-width:100%; //En lugar de width:100%
	white-space: nowrap;
}

No hacia falta la mención de mi persona. Gracias por tu ayuda.
Responder
Imágen de perfil
28 de Octubre del 2018
estrellaestrellaestrellaestrellaestrella
¡Muy útil la aportación!.
Responder

Comentar la versión: Versión 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s4705