3 回答
TA贡献1943条经验 获得超7个赞
首先javascript脚本是线性执行的
<javascript>
运算A
运算B
运算C
</javascript>
执行了"A"才会执行B,然后才会执行C
之所以出现你说的异步现象。是因为你调用BMap.Map类getPoint是个ajax
这个ajax是一个http请求。不受javascript程序执行的限制
因为。getPoint就跳出了这个javascript脚本。自己去执行了,而脚本继续下一个语句alert(d1)
因此-----------
function(point){
if (point) {
map.centerAndZoom(point, 16);
map.addOverlay(new BMap.Marker(point));
d1=point.lng;
}
}
----------------------
这个ajax反回后才执行的方法。并没有工作
所以d1没有=point.lng
如果象得到ajax请求后的d1结果
请在
d1=point.lng;后面加入:
alert(d1);
TA贡献1848条经验 获得超10个赞
ajax框架很多都提供了同步访问的功能,但是不推荐使用,因为在等待数据返回时,ui线程被占用,是浏览器出现无法响应的情况。
可以使用setTimeOut来设置延时等待数据返回。
示例代码如下。
var d1=-1;
var waitTimer=null;
//doajax
var doSuccess = fucntion(){
if(d1!=-1)
{
alert(d1);
}else{
waiTimer = setTimeOut(doSuccess,100);//设置100毫秒的延时
}
};
doSuccess ();
不保证代码的正确性,只是告诉你大概的思路。
TA贡献1818条经验 获得超8个赞
var map = new BMap.Map("container");
var myGeo = new BMap.Geocoder();
var address="金沙江路129号";
var d1=0;
myGeo.getPoint(address, function(point){
if (point) {
map.centerAndZoom(point, 16);
map.addOverlay(new BMap.Marker(point));
d1=point.lng;
outer();
}
}, "上海市");
function outer(){
alert(d1);
}
添加回答
举报