2017-03-04 50 views
1

当我尝试从反向地理编码方法中的URL获取json时出现问题: 我根据在stackoverflow上找到的解决方案尝试了此操作。 当我尝试以显示我的警报JSON它表明:我想从JSON的“DISPLAY_NAME”,以便把它在文本输入后未定义从URL获取json并显示特定数据

adressReverseGeoCode(item: any, elementId: any) { 
var getJSON = (url: any, callback: any) => { 
    var xhr = new XMLHttpRequest(); 
    xhr.open('GET', url, true); 
    xhr.responseType = 'json'; 
    xhr.onload =() => { 
    var status = xhr.status; 
    if (status == 200) { 
     callback(null, xhr.response); 
    } else { 
     callback(status); 
    } 
    }; 
    xhr.send(); 
}; 

getJSON('http://nominatim.openstreetmap.org/reverse?format=json&lat=' + item.latitude + '&' + 'lon=' + item.longitude + '&addressdetails=1', 
    (err: any, data: any) => { 
    if (err != null) { 
     alert('Something went wrong: ' + err); 
    } else { 
     alert(data.result); 
    } 

    }); 

} 

。 你可以试试这个链接查看JSON文件

{ 
"place_id":"154253419", 
"licence":"Data © OpenStreetMap contributors, ODbL 1.0. http:\/\/www.openstreetmap.org\/copyright", 
"osm_type":"way", 
"osm_id":"424211755", 
"lat":"-23.56183", 
"lon":"-46.6598392", 
"display_name":"Alameda Ministro Rocha Azevedo, Jardim Paulista, São Paulo, Microrregião de São Paulo, RMSP, Mesorregião Metropolitana de São Paulo, São Paulo, Southeast Region, 01410-001, Brazil", 
"address":{"road":"Alameda Ministro Rocha Azevedo","suburb":"Jardim Paulista","city_district":"Jardim Paulista","city":"São Paulo","county":"Microrregião de São Paulo","state_district":"Mesorregião Metropolitana de São Paulo","state":"São Paulo","postcode":"01410-001","country":"Brazil","country_code":"br"}, 
"boundingbox":["-23.5642064","-23.5601209","-46.662319","-46.6580485"] 
} 

预先感谢您的任何帮助,您可以给我!

+1

没有data.result!这就是为什么它是未定义的。您的数据是JSON。所以只要'data.display_name' – Smit

+2

也必须解析json字符串到对象。 – charlietfl

回答

1

没有data.result!这就是为什么它是未定义的。您的数据是JSON。所以只需要data.display_name。大概!

var obj = JSON.parse(data); // as suggested by @charlietfl 
console.log(obj.display_name); 
alert(obj.display_name); 
+1

谢谢,一旦冷却时间结束,我会在4分钟内接受你的回答^^ – Uness