Código de JQuery - Leer una lista multidimensional de valores recursivamente

Imágen de perfil

Leer una lista multidimensional de valores recursivamentegráfica de visualizaciones


JQuery

Publicado el 2 de Noviembre del 2019 por Administrador (703 códigos)
680 visualizaciones desde el 2 de Noviembre del 2019
Si disponemos de un json del cual no conocemos la cantidad de niveles que puede tener, por ejemplo en un árbol genealógico hay personas que pueden tener hijos, y esos hijos también pueden tener más hijos, y así se creará un juego de nodos que se irá expandiendo de arriba hacia abajo, sin saber su límite.

En este código, de manera recursiva muestra como obtener todos los valores.

20170921

Publicado el 2 de Noviembre del 2019gráfica de visualizaciones de la versión: 20170921
681 visualizaciones desde el 2 de Noviembre del 2019
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella


Forma parte de Mostrar lista multidimensional en Javascript
 
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
<!DOCTPYE html>
<html>
<head>
	<meta charset="UTF-8">
	<title> Categorías </title>
</head>
<body>
	<div>
		<h1> Categorias </h1>
		<div id="categorias">
		</div>
	</div>
	<script type="text/javascript" src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
	<script type="text/javascript">
		var categorias = [
			{nombre: 'Deportes', url: '#deportes', sub: [
				{nombre: 'Fútbol', url: '#futbol', sub: [
					{nombre: 'Lionel Messi', url: '#messi', sub: []},
					{nombre: 'Cristiano Ronaldo', url: '#cristiano_ronaldo', sub: []},
					{nombre: 'Neymar', url: '#neymar', sub: []},
					{nombre: 'James Rodríguez', url: '#james_rodriguez', sub: []},
					{nombre: 'Alexis Sánchez', url: '#alexis_sanchez', sub: []},
					{nombre: 'Paolo Guerrero', url: '#paolo_guerrero', sub: []},
					{nombre: 'Luis Suárez', url: '#luis_suarez', sub: []}
				]},
				{nombre: 'Tenis', url: 'tenis', sub: [
					{nombre: 'Roger Federer', url: '#roger_federer', sub: []},
					{nombre: 'Rafael Nadal', url: '#rafael_nadal', sub: []}
				]}
			]},
			{nombre: 'Economía', url: '#economia', sub: [
				{nombre: 'Peso', url: '#peso', sub: []},
				{nombre: 'Dólar', url: '#dolar', sub: []},
				{nombre: 'Euro', url: '#euro', sub: []}
			]},
			{nombre: 'Política', url: '#politica', sub: [
				{nombre: 'Argentina', url: '#argentina', sub: [
					{nombre: 'Cristina Kirchner', url: '#cfk', sub: []},
					{nombre: 'Mauricio Macri', url: '#macri', sub: []}
				]}
			]}
		];
		function dibujarCategorias(p_categorias){
			var ul = $('<ul></ul>');
			for(var i = 0; i < p_categorias.length; i++){
				var li = $('<li></li>');
				var span = $('<span> ' + p_categorias[i].nombre + ' </span>');
				li.append(span);
				if(p_categorias[i].sub.length > 0){
					li.append(dibujarCategorias(p_categorias[i].sub));
				}
				ul.append(li);
			}
			return ul;
 
		}
		$("#categorias").html(dibujarCategorias(categorias));
	</script>
</body>
</html>



Comentarios sobre la versión: 20170921 (0)


No hay comentarios
 

Comentar la versión: 20170921

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