Foros del Web » Programando para Internet » Javascript »

imprimir esta variable

Estas en el tema de imprimir esta variable en el foro de Javascript en Foros del Web. Tengo este código extraido de un api de google maps, me gustaria imprimir la variable "name", en este caso conocida como washington Código PHP:    ...
  #1 (permalink)  
Antiguo 11/03/2009, 16:40
Avatar de karlic0s  
Fecha de Ingreso: abril-2007
Ubicación: Cartagena (Murcia)
Mensajes: 241
Antigüedad: 17 años, 8 meses
Puntos: 18
imprimir esta variable

Tengo este código extraido de un api de google maps, me gustaria imprimir la variable "name", en este caso conocida como washington

Código PHP:
  var city = [
    {
      
name"washington",
      
Status: {
        
code200,
        
request"geocode"
      
},
      
Placemark: [
        {
          
address"washington",
          
population"0.563M",
          
Point: {
            
coordinates: [0.9063231.7687990]
          },
          
AddressDetails: {
            
Country: {
              
CountryNameCode"US",
              
AdministrativeArea: {
              
AdministrativeAreaName"DC",
                
Locality: {LocalityName"washington"}
              }
            }
          }
        }
      ]
    }, 
He probado con document.write(city[name]); pero no me funciona, me da undefined, alguna solución?

Saludos y gracias!!

Última edición por karlic0s; 11/03/2009 a las 16:51
  #2 (permalink)  
Antiguo 11/03/2009, 16:51
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años, 8 meses
Puntos: 839
Respuesta: imprimir esta variable

mmm... city[0].name
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
  #3 (permalink)  
Antiguo 11/03/2009, 17:04
Avatar de karlic0s  
Fecha de Ingreso: abril-2007
Ubicación: Cartagena (Murcia)
Mensajes: 241
Antigüedad: 17 años, 8 meses
Puntos: 18
Respuesta: imprimir esta variable

Cita:
Iniciado por David el Grande Ver Mensaje
mmm... city[0].name
Es parecido a lo que yo queria, pero no es lo que yo quiero, puesto que solo me imprime el resultado de la primera variable, pongo el código completo (aunque es largo y mas de uno pasará de leer :P) a ver si algun alma caritativa es capaz de echarme una mano.
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
>
<
html xmlns="http://www.w3.org/1999/xhtml" 
      
xmlns:v="urn:schemas-microsoft-com:vml">
  <
head>
    <
meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
    <
title>Google Maps JavaScript API ExampleGeocoding Cache</title>
    <
script src="http://maps.google.com/maps?file=api&amp;v=2.x&amp;key=ABQIAAAAzr2EBOXUKnm_jVnk0OJI7xSosDVG8KKPE1-m51RBrvYughuyMxQ-i1QfUnH94QxWIa6N4U6MouMmBA" 
      
type="text/javascript"></script>
    <script type="text/javascript">

  // Builds an array of geocode responses for the 5 cities.
  var city = [
    {
      name: "Washington, DC",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Washington, DC, USA",
          population: "0.563M",
          Point: {
            coordinates: [-77.036667, 38.895000, 0]
          },
          AddressDetails: {
            Country: {
              CountryNameCode: "US",
              AdministrativeArea: {
              AdministrativeAreaName: "DC",
                Locality: {LocalityName: "Washington"}
              }
            }
          }
        }
      ]
    },
    {
      name: "Tokyo, Japan",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Tokyo, Japan",
          population: "12.527M",
          Point: {
            coordinates: [139.770004, 35.669998, 0]
          },
            AddressDetails: {
            Country: {
              CountryNameCode: "US",
              AdministrativeArea: {
                AdministrativeAreaName: "CA",
                Locality: {LocalityName: "Los Angeles"}
              }
            }
          }
        }
      ]
    },
    {
      name: "Paris, France",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Paris, France",
          population: "2.144M",
          Point: {
            coordinates: [2.351019, 48.856662, 0]
          },
          AddressDetails: {
            Country: {
              CountryNameCode: "FR",
              Locality: {LocalityName: "Paris"}
            }
          }
        }
      ]
    },
    {
      name: "Rome, Italy",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Rome, Italy",
          population: "2.553M",
          Point: {
            coordinates: [12.482181, 41.895431, 0]
          },
          AddressDetails: {
            Country: {
              CountryNameCode: "IT",
              Locality: {LocalityName: "Roma"}
            }
          }
        }
      ]
    },
    {
      name: "Berlin, Germany",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Berlin, Germany",
          population: "3.396M",
          Point: {
            coordinates: [13.411895, 52.523781, 0]
          },
          AddressDetails: {
            Country: {
              CountryNameCode: "DE",
              Locality: {LocalityName: "Berlin"}
            }
          }
        }
      ]
    },
    {
      name: "Madrid, Spain",
      Status: {
        code: 200,
        request: "geocode"
      },
      Placemark: [
        {
          address: "Madrid, Spain",
          population: "3.228M",
          Point: {
            coordinates: [-3.703270, 40.416712, 0]
          },
          AddressDetails: {
            Country: {
              CountryNameCode: "ES",
              Locality: {LocalityName: "Madrid"}
            }
          }
        }
      ]
    }
  ];


  var map;
  var geocoder;

  // CapitalCitiesCache is a custom cache that extends the standard GeocodeCache.
  // We call apply(this) to invoke the parent's class constructor.
  function CapitalCitiesCache() {
    GGeocodeCache.apply(this);
  }

  // Assigns an instance of the parent class as a prototype of the
  // child class, to make sure that all methods defined on the parent
  // class can be directly invoked on the child class.
  CapitalCitiesCache.prototype = new GGeocodeCache();

  // Override the reset method to populate the empty cache with
  // information from our array of geocode responses for capitals.
  CapitalCitiesCache.prototype.reset = function() {
    GGeocodeCache.prototype.reset.call(this);
    for (var i in city) {
      this.put(city[i].name, city[i]);
    }
  }

  function initialize() {
    map = new GMap2(document.getElementById("map_canvas"));
    map.setCenter(new GLatLng(37.441944, -122.141944), 6);
    geocoder = new GClientGeocoder();
    geocoder.setCache(new CapitalCitiesCache());
  }

  function addAddressToMap(response) {
    map.clearOverlays();

    if (response && response.Status.code != 200) {
      alert("Unable to locate " + decodeURIComponent(response.name));
    } else {
      var place = response.Placemark[0];
      var point = new GLatLng(place.Point.coordinates[1],
                              place.Point.coordinates[0]);
      map.setCenter(point, 6);
      map.openInfoWindowHtml(point, "<b>City:</b> " + place.address
       + "<br><b>Population:</b> " + place.population);
    }
  }

  function findCity(which) {
    if (which != 0) {
      geocoder.getLocations(city[which - 1].name, addAddressToMap);
    }
  }

document.write(city[status].name);
  </script>
</head>
<body onload="initialize()">

  <table>
  <tr>
    <td align="center">
      <b>Go to:</b>
      <select onchange="findCity(this.selectedIndex)">
        <option>Select capital</option>
        <option>Washington, USA</option>

        <option>Tokyo, Japan</option>
        <option>Paris, France</option>
        <option>Rome, Italy</option>
        <option>Berlin, Germany</option>
        <option>Madrid, Spain</option>
      </select>

    </td>
  </tr>
  <tr>
    <td>
      <div id="map_canvas" class="map" style="width:450px;height:400px"></div>
    </td>
  </tr>
  </table>
</body>

</html> 
Cuando selecciono con el select la variable cambia, necesito imprimir la variable name, según el nombre de la variable en ese momento.

Saludos
  #4 (permalink)  
Antiguo 11/03/2009, 19:31
Avatar de David
Moderador
 
Fecha de Ingreso: abril-2005
Ubicación: In this planet
Mensajes: 15.720
Antigüedad: 19 años, 8 meses
Puntos: 839
Respuesta: imprimir esta variable

En la función findCity puedes mostrar el valor de la variable usando:
Código javascript:
Ver original
  1. alert(city[which - 1].name);
O hasta puedes usar el texto de la opción seleccionada, que ese el mismo.
__________________
Por favor, antes de preguntar, revisa la Guía para realizar preguntas.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 02:00.