javascript:我想顯示城市和州填寫郵政編碼時。我有地理位置工作,但現在我只想要城市和州顯示郵政填充時在隱藏顯示城市和狀態,當郵編填充
這是我的HTML:
<label for="city">City</label>
<input size="20" placeholder="Town or City" name="city" id="city" type="text">
<br>
<label for="state">State</label>
<input size="10" placeholder="State/Province" name="state" id="state" type="text">
這是我的JavaScript:
zip.addEventListener("change", getGeo);
function getGeo(e){
// make an send an XmlHttpRequest
var x = new XMLHttpRequest();
x.open("GET","http://maps.googleapis.com/maps/api/geocode/json?address="+this.value,true);
x.send();
// set up a listener for the response
x.onreadystatechange=function(){
if (this.readyState==4 && this.status==200){
var c = JSON.parse(this.response).results[0].address_components[1].long_name;
//alert(c);
var s = JSON.parse(this.response).results[0].address_components[2].short_name;
//alert(s);
if (c) {
city.value = c;
}
if (s) {
state.value = s;
}
//document.getElementById("output").innerHTML = o;
var l = JSON.parse(this.response).results[0].geometry.location;
if (l.lat) {
lat.value = l.lat;
}
if (l.lng) {
lon.value = l.lng;
}
}
}
}
這一切都在這的jsfiddle http://jsfiddle.net/lakenney/gad7ntgk/
目前還不清楚你在問什麼。從地理編碼請求返回時,您是否想要顯示city + state字段? –
爲什麼你json解析響應多次?將解析結果存儲一次......效率更高 – charlietfl