首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > JavaScript >

js异常总结一:同步与异步

2013-12-13 
js错误总结一:同步与异步1.同步与异步$.post(http://10.200.1.22:8983/solr/collection1/select,{q:qu

js错误总结一:同步与异步
1.同步与异步

$.post("http://10.200.1.22:8983/solr/collection1/select",{"q":query,"wt":"json","indent":true,"rows":10},function(data){var response  = data.response;   var docs =  response.docs;for(var i = 0;i<docs.length;i++){           var url = docs[i].entry_url;    var li = $('<li><a href =#">'+docs[i].source_name+'</a></li>');  $("#card1").append(li);li.click(function(){  myWindow = openWindow();                     loadWindowContent(myWindow,url); });}},'json');

上面的代码执行的时候点击相应的锚文本,连接中出现的信息不对。原因上述的
li.click(function(){ myWindow = openWindow();  loadWindowContent(myWindow,url); });
是并发的,相当于在新的线程中执行,url跟for循环第一行的url不一致。解决办法:
将for循环中的代码改为:
var li = $('<li  data-url="'+docs[i].entry_url+'"><a href ="#">'+docs[i].source_name+'</a></li>');$("#card1").append(li);li.click(function(){ myWindow = openWindow();  loadWindowContent(myWindow,$(this).attr('data-url')); });

热点排行