делаю расчет доставки почтой России вроде все нормально.
отправил запрос, получил список городов (список появился в селекте).
потом отправил этой же функцией рассчет стоимости, а он мне опять помимо ответа возвращает этот список городов. функция почему-то запускается 2 раза. и список городов тогда не появляется.
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
</head><body>
Точка прибытия: <select id="arrivalPoint"></select>
<script>
// This line taken from J50Npi.min.js (within this repo)
var J50Npi={currentScript:null,getJSON:function(b,d,h){var g=b+(b.indexOf("?")+1?"&":"?");var c=document.getElementsByTagName("head")[0];var a=document.createElement("script");var f=[];var e="";this.success=h;d.callback="J50Npi.success";for(e in d){f.push(e+"="+encodeURIComponent(d[e]))}g+=f.join("&");a.type="text/javascript";a.src=g;if(this.currentScript){c.removeChild(currentScript)}c.appendChild(a)},success:null};
var url = 'http://emspost.ru/api/rest/?method=ems.get.locations&callback=arrivalPointRender';
var data = {plain: "true", type:"russia"};
// We need a function callback to be executed after the response is received
var arrivalPointRender = function(data){
var html = '', selected = false;
for(var i = 0; i < data.rsp.locations.length; i++){
if(data.rsp.locations[i].type=="cities") {data.rsp.locations[i].type="(город)"};
if(data.rsp.locations[i].type=="regions") {data.rsp.locations[i].type="(регион)"};
html += '<option value="'+data.rsp.locations[i].value+'"'+(selected?'':' selected')+'>'+data.rsp.locations[i].name+' '+data.rsp.locations[i].type +'</option>'
selected = false
}
document.getElementById('arrivalPoint').innerHTML = html;
}
J50Npi.getJSON(url, data, arrivalPointRender);
var urlCalcPost = 'http://emspost.ru/api/rest?method=ems.calculate&callback=CalcPost&from=city--moskva&to=region--omskaja-oblast&weight=1.5';
var dataCalcPost = {plain: "true"};
var CalcPost = function(dataCalcPost){
console.log(dataCalcPost.rsp);
alert(" почему 2 алерта?" );
};
J50Npi.getJSON (urlCalcPost, dataCalcPost, CalcPost);
</script>
</body>
</html>
в консоле такая запись {locations: Array[197], stat: "ok"}
{price: "950", stat: "ok", term: Object {...}}
то есть получил массив городов и стоимость доставки. вот тут код
http://jsfiddle.net/tL532q27/3/
до этого делал деловые линии точно так же никаких проблем не было. Замучался уже.
