Hey mensen,
Even een vraagje over het volgende AJAX script.
Ik probeerde een functie te maken waarmee je een waarde en een plaats meegeeft waarin de uitvoer van de functie showHints komt.
De eerste


    alert("Plaats is: " + plaats);

werkt.
De tweede echter wordt niet uitgevoerd.

Ik heb dit script uitgetest, zonder de variabele plaats en dan een id van een div opgegeven.
Dan doet dit script het wel, een beetje gek.

Ik wil echter een algemene functie maken waarmee ik niet gebonden ben aan 1 div naam, vandaar de var plaats.

Heb ook gegoogled, meerdere mensen hebben dit probleem, ik heb echter nergens een werkende oplossing gezien, vandaar
dat jullie misschien kunnen helpen?

<script type="text/javascript">
function showHints(zoekterm,plaats)
{
	if(zoekterm.length == 0)
	{
		document.getElementedById(plaats).innerHTML = "";
		return;
	}
	xmlHttp = GetXmlHttpObject();
	
	if(xmlHttp == null)
	{
		window.alert("Sorry, maar u kunt geen AJAX-functies gebruiken");
		return;
	}
	else
	{			
		var url = "zoeknaam.php";
		url = url + "?zoekterm=" + zoekterm;
		url = url + "&rand=" + Math.random();
		xmlHttp.onreadystatechange = stateChanged(plaats);
		xmlHttp.open("GET", url, true);
		xmlHttp.send(null);
		
	}
}


function GetXmlHttpObject()
{
	var xmlHttp=null;
	try
	{
		// Firefox, Opera 8.0+, Safari
		xmlHttp=new XMLHttpRequest();
	}
	catch (e)
	{
		// Internet Explorer
		try
		{
			xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
		}
	 	catch (e)
		{
			xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
		}
	}
	
	if(!xmlHttp)
	{
		alert("Sommige functies zijn niet beschikbaar");
	}
	
	return xmlHttp;
}


function stateChanged(plaats) 
{ 
		alert("Plaats is: " + plaats);		
	if (xmlHttp.readyState == 4)
	{ 	
		alert("Plaats is: " + plaats);	
		document.getElementById(plaats).innerHTML=xmlHttp.responseText;
	}
}
</script>


Bij voorbaat bedankt!
xmlHttp.onreadystatechange = stateChanged(plaats);

Nu wordt stateChanged direct uitgevoerd, en wordt het resultaat van die functie aan onreadystatechange toegewezen. Wat jij zoekt is

xmlHttp.onreadystatechange = function() {
    stateChanged(plaats);
};
Ja super bedankt!

Reageren