0
我创建了一个谷歌的Chrome扩展,从企业获取的商家信息的详细信息页面,并获取城市,州和邮编使用企业的地址与谷歌的地理编码的帮助API。我使用localStorage
像下面存储城市,州和销值:localStorage的不工作,如果一个网页已经打开
var city = "", state = "", pin = "";
var url = "https://maps.googleapis.com/maps/api/geocode/json?address="+encodeURIComponent(laddress[1].replace(/<.*?>/g,'').replace('&','&').trim())+"&sensor=false&key=AIzaSyCAQmrAKh0jzNVcT1VqTUhjB5Oh_dxl1zA";
console.log(url);
var xhr = new XMLHttpRequest();
var resp;
xhr.open("GET", url, true);
xhr.setRequestHeader("Content-Type", "*/*");
xhr.onload = function() {
var json = xhr.responseText; // Response
json = json.replace(/^[^(]*\(([\S\s]+)\);?$/, '$1'); // Turn JSONP in JSON
json = JSON.parse(json);
console.log(json.results[0].address_components);
for(var i=0;i<json.results[0].address_components.length;i++){
if(json.results[0].address_components[i].types[0]=="administrative_area_level_2")
city = json.results[0].address_components[i].long_name;
if(json.results[0].address_components[i].types[0]=="administrative_area_level_1")
state = json.results[0].address_components[i].long_name;
if(json.results[0].address_components[i].types[0]=="postal_code")
pin = json.results[0].address_components[i].long_name;
}
localStorage.setItem("city", city);
localStorage.setItem("state", state);
localStorage.setItem("pin", pin);
}
xhr.send();
lcity = localStorage.getItem("city");
lstate = localStorage.getItem("state");
lpin = localStorage.getItem("pin");
问题出现时
- 业务页面已经打开,我尝试单击扩展,localStorage的不会工作
- 有时,它没有表现出任何价值,有时它显示了值。
我应该怎么做才能在访问多个业务页面时获得localStorage
的完美值?
你的情况相当于https://stackoverflow.com/questions/14220321/how-to-return-the-response-from-an-ajax-call - 你试图将它设置之前使用的值。 – Xan 2015-02-10 15:54:14