'Variable is not visible which gets the value in one loop and access in another loop in ajax
$(document).ready(function(){
// This function get the search results from Solr server
$("#submit").click(function(){
var query=getquerystring() ; //get the query string entered by user
// get the JSON response from solr server
var newquery=query;
$.ajax({
url: "http://192.168.1.9:8983/solr/db/select/?wt=json&&start=0&rows=100&q="+query+"&spellcheck=true&json.wrf=?",
async:false,
dataType: 'json',
success: function(newresult){
var html="<table><tr>"
var count=0;
var alt="NoImage";
var size="3pt";
var id;
var flag=1; // Flag for error messages
border="1";
var n=newresult.response.numFound
var uid=new Array(n);
// If no search results
if(newresult.response.numFound==0)
{
var msg= "<hr /><font size="+size+" >We're sorry, we found no results for <b>"+document.getElementById("queryString").value+"</font><hr />";
}
else
{
/* var msg= "<hr /><font size="+size+" >Total Results Found <b> "+ result.response.numFound+"</b> for "+"<b>"+document.getElementById("queryString").value+"</b> keyword</font><hr /> ";*/
// Parse solr response and display it on web page
$.each(newresult.response.docs, function(i,item){
uid[i]=item.UID_PK;
});
$.each(newresult.highlighting, function(i,item1){
alert(uid[i]);
});
}
});
});
// get the query string entered by user
function getquerystring() {
var query=document.getElementById("queryString").value;
//qstr = escape(query);
return query;
}
});
in this uid[] which gets the value in
$.each(newresult.response.docs, function(i,item){
uid[i]=item.UID_PK;
});
I want to access this uid[] in next loop
$.each(newresult.highlighting, function(i,item1){
alert(uid[i]);
});
but uid[] is not visible in second each() loop, the alert shows undefined here. Why is so? What I need to do to make uid[] visible in second loop.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|
