Código de JavaScript - Seleccionar la opción de menú según la pagina donde estamos con JavaScript

Imágen de perfil
Val: 2.134
Oro
Ha aumentado 1 puesto en JavaScript (en relación al último mes)
Gráfica de JavaScript

Seleccionar la opción de menú según la pagina donde estamos con JavaScriptgráfica de visualizaciones


JavaScript

Actualizado el 30 de Junio del 2020 por Joel (120 códigos) (Publicado el 28 de Junio del 2020)
348 visualizaciones desde el 28 de Junio del 2020
Código de busca la url de la pagina donde nos encontramos dentro de las urls del menú de nuestra pagina y añade un estilo a dicho enlace para diferenciarlo del resto. En este ejemplo se añade el estilo CSS "selected" que lo pone en negrita.

Puedes ver el mismo código en JQuery en: https://www.lawebdelprogramador.com/codigo/JQuery/6329-Seleccionar-la-opcion-se-menu-segun-la-pagina-donde-estamos-con-JQuery.html

Versión 1
estrellaestrellaestrellaestrellaestrella(3)

Publicado el 28 de Junio del 2020gráfica de visualizaciones de la versión: Versión 1
348 visualizaciones desde el 28 de Junio del 2020
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
<!DOCTYPE html>
<html>
<head>
 
<style>
a:link, a:visited, a:hover {color:Blue;}
.selected {font-weight:bold;}
</style>
 
</head>
<body>
 
<ul>
    <li><a href="pagina1.html">pagina1</a></li>
    <li><a href="pagina2.html">pagina2</a></li>
    <li><a href="pagina3.html">pagina3</a></li>
    <li><a href="x3.html">pagina4</a></li>
    <li><a href="pagina5.html">pagina5</a></li>
    <li><a href="pagina6.html">pagina6</a></li>
</ul>
 
</body>
</html>
 
<script>
const basename = url => url.split("/").reverse()[0];
 
// La función filter, solo nos devuelve los elementos que cumplen con la condicion
const coincidencia=Array.from(document.querySelectorAll('ul > li a[href]')).filter(el =>
    // obtenemos cada uno de los nombres de las urls y lo comparamos con el nombre
    // de la url de la pagina actual
    basename(el.href) === basename(window.location.pathname)
)
 
// Añadimos la clase "selected" solo si hay alguna coincidencia
coincidencia.length>0 ? coincidencia[0].classList.add('selected') : undefined;
</script>



Comentarios sobre la versión: Versión 1 (3)

Hace 7d
estrellaestrellaestrellaestrellaestrella
Hola, tengo una duda...

1
2
3
4
const coincidencia=Array.from(document.querySelectorAll('ul > li a[href]')).filter(el =>
// obtenemos cada uno de los nombres de las urls y lo comparamos con el nombre
// de la url de la pagina actual
basename(el.href) === basename(window.location.pathname)

¿Cómo podría declarar los enlaces de los <li> que tienen una clase determinada?
gracias.
Responder
Imágen de perfil
Hace 7d
estrellaestrellaestrellaestrellaestrella
No se muy bien como lo tienes, pero por ejemplo, sin en el <a href... tienes la class="opcion1", seria algo así:

1
'ul > li a[href].opcion1'
Responder
Imágen de perfil
Hace 3d
estrellaestrellaestrellaestrellaestrella
No ha dejado ningún comentario
Responder

Comentar la versión: Versión 1

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/s6328